我有一个呈现数组对象的简单模板。但是,它失败并显示以下消息:
System.out.println(new Zombie());
数组以自定义元素的属性传递,格式如下:
[dom-repeat::dom-repeat]: expected array for `items`, found [{"code":1,"name":"Item #1"},{"code":2,"name":"Item #2"},{"code":3,"name":"Item #3"}]
我已多次阅读docs on template repeaters但仍无法找到我做错的事。
任何帮助将不胜感激!
这是我的自定义元素:
[{"code":1,"name":"Item #1"},{"code":2,"name":"Item #2"},{"code":3,"name":"Item #3"}]
现在我用它了:
<dom-module id="x-myelement">
<template>
<div>
<h1>{{title}}</h1>
<ul>
<template is="dom-repeat" as="menuitem" items="{{items}}">
<li><span>{{menuitem.code}}</span></li>
</template>
</ul>
</div>
</template>
<script>
(function() {
Polymer({
is: 'x-myelement',
title: String,
items: {
type: Array,
notify: true,
value: function(){ return []; }
}
});
})();
</script>
</dom-module>
答案 0 :(得分:4)
您需要将元素属性放入properties
对象(请参阅Polymer documentation on properties):
Polymer({
is: 'x-myelement',
properties: {
title: String,
items: {
type: Array,
notify: true,
value: function() {return [];}
}
}
});
否则Polymer没有关于您的属性的信息。它将项目视为字符串,并未将属性值解析为JSON数组。最后,dom-repeat
也为其items
属性传递了一个字符串,导致您看到错误。