如何迭代通过一个数组的对象在聚合物
How to iterate through an array of objects in polymer
所以我可以很容易地遍历数组或列表。
<template is="dom-repeat" items="{{inputs}}">
<paper-input label={{item}} id={{item}} style="width:5em"></paper- input>
</template>
然而,我在迭代对象数组时遇到了问题。
<iron-data-table id="outputtable" items="{{output}}">
<template is="dom-repeat" items="[[output]]">
<data-table-column name="[[item.key]]">
<template>[[item.value]]</template>
</data-table-column>
</template>
</iron-data-table>
这段代码可能不正确,但我无法越过错误
Polymer::Attributes: cannot decode Array as JSON
我迭代字符串数组的第一个例子,我实际上想迭代对象数组,但没有做到。
[{"uri":"/emoji/1"},{"uri":"/emoji/2"}]
对象数组的简单例子。
<iron-ajax id="ajaxPost" url={{url}} handle-as="json" content-type="application/json" method="POST" on-response=clearAndOutput > </iron-ajax>
this.output [Object { uri="/emoji/1"}, Object { uri="/emoji/2"}, Object { uri="/emoji/3"}, 35 more...]
clearAndOutput: function(data) {
this.returnvalue = data.detail.response;
}
在dom-repeat
中,items
数组的每个数组元素都可以被重复器模板中的item
访问(尽管您可以选择不同的迭代器名称)。如果名为"output"
的数组包含"uri"
属性,则可以在模板中像这样迭代该数组:
<template is="dom-repeat" items="[[output]]">
<div>[[item.uri]]</div>
</template>
HTMLImports.whenReady(() => {
Polymer({
is: 'x-foo',
properties: {
output: {
type: Array,
value: () => [{"uri":"/emoji/1"},{"uri":"/emoji/2"}]
}
}
});
});
<head>
<base href="https://polygit.org/polymer+1.7.0/components/">
<script src="webcomponentsjs/webcomponents-lite.min.js"></script>
<link rel="import" href="polymer/polymer.html">
</head>
<body>
<x-foo></x-foo>
<dom-module id="x-foo">
<template>
<template is="dom-repeat" items="[[output]]">
<div>[[item.uri]]</div>
</template>
</template>
</dom-module>
</body>
codepen
您看到的错误表明"output"
实际上不是一个数组,因此您必须调试它(或提供有关如何设置它以帮助解决问题的其他信息)。
相关文章:
- Javascript(Angular)从一个对象数组到第二个数组查找值
- 根据id将json数组组合为一个json数组
- JavaScript数组包含一个值
- 对一个对象使用reduce可以返回一个没有't在数组中包含目标字母
- jQuery$.inArray()总是返回-1和一个对象数组
- 在数组中的一个元素上设置多个值
- javascript处理一个对象数组以获得一个新的对象数组
- 作为一个二维数组,从ajax接收
- 你能用来自数组的属性名称生成一个对象吗
- 多维关联数组的最后一个索引
- 如何创建一个方法来验证数组的范围
- 循环以检查数组中的最后一个图像
- 在Javascript中将一个值和字符串数组转换为if语句
- 算法:从数组(javascript/angular)中按当前日期获取上一个和下一个事件
- 如何将一个对象添加到每个对象数组中
- 如何创建一个谷歌地图地理坐标数组
- 如何从另一个带下划线的数组中筛选带元素的数组
- 使用window.location.htm和匹配的URL数组(一个用于桌面,一个用于移动)将桌面网站重定向到移动
- Javascript排序多维数组-一个完整的例子
- 刽子手的游戏.2数组.一个需要相应地更新另一个