首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >聚合物1.x:如何预处理列表或中继器中的项目?

聚合物1.x:如何预处理列表或中继器中的项目?
EN

Stack Overflow用户
提问于 2016-10-17 21:27:52
回答 2查看 71关注 0票数 0

这是普伦克

有人能指出一种模式,例如格式化(或预处理)进入中继器(如iron-listiron-data-table)的数据项吗?

换句话说,就拿这个例子来说吧。。假设我想向每个用户添加一个字段并将其显示在列表中;让我们将其命名为namelength

代码语言:javascript
复制
item.user.namelength = item.user.name.first.length + item.user.name.last.length

如何(在HTML或JS中的位置以及使用什么模式)最好地处理这个预处理任务?

content-el.html

代码语言:javascript
复制
<base href="https://polygit.org/polymer+:master/iron-data-table+Saulis+:master/components/">
<link rel="import" href="polymer/polymer.html">
<script src="webcomponentsjs/webcomponents-lite.min.js"></script>

<link rel="import" href="iron-ajax/iron-ajax.html">
<link rel="import" href="paper-button/paper-button.html">

<link rel="import" href="iron-data-table/iron-data-table.html">

<dom-module id="content-el">
    <template>
        <style></style>

    <iron-ajax
      auto
      url="https://saulis.github.io/iron-data-table/demo/users.json" 
      last-response="{{users}}">
    </iron-ajax>
    <iron-data-table items="[[users.results]]">
      <data-table-column name="Picture" width="50px" flex="0">
        <template>
          <img src="[[item.user.picture.thumbnail]]">
        </template>
      </data-table-column>
      <data-table-column name="First Name">
        <template>[[item.user.name.first]]</template>
      </data-table-column>
      <data-table-column name="Last Name">
        <template>[[item.user.name.last]]</template>
      </data-table-column>
      <data-table-column name="Email">
        <template>[[item.user.email]]</template>
      </data-table-column>
    </iron-data-table>

    </template>

  <script>
    (function() {
      'use strict';
      Polymer({
        is: 'content-el',
            });
        })();
  </script>
</dom-module>
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-10-17 21:42:45

例如。

代码语言:javascript
复制
<data-table-column name="Name Length">
    <template>{{_len(item.user.name.first, item.user.name.last)}}</template>
</data-table-column>

..。

代码语言:javascript
复制
(function() {
  'use strict';
  Polymer({
    is: 'content-el',
    _len: function(first, last) {
      return first.length + last.length;
    }
        });
    })();
票数 1
EN

Stack Overflow用户

发布于 2016-10-18 03:44:41

通过添加您描述的计算绑定字段,您可以使用预处理user.resultsnamelength

代码语言:javascript
复制
// template
<iron-data-table items="[[_getUserData(users.results)]]">
  ...
  <data-table-column name="Name Length">
    <template>[[item.user.namelength]]</template>
  </data-table-column>
</iron-data-table>

// script
Polymer({
  is: 'content-el',
  _getUserData: function(items) {
    items.forEach(function(item) {
      var user = item.user;
      user.namelength = user.name.first.length + user.name.last.length;
    });
    return items;
  }
});

柱塞

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40095936

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档