dom-重复模板无法呈现数组并出现错误 'expected array for items'
dom-repeat template fails to render array with error 'expected array for items'
我有一个呈现数组对象的简单模板。但是,它失败并显示以下消息:
[dom-repeat::dom-repeat]: expected array for `items`, found [{"code":1,"name":"Item #1"},{"code":2,"name":"Item #2"},{"code":3,"name":"Item #3"}]
数组按以下格式传入自定义元素的属性:
[{"code":1,"name":"Item #1"},{"code":2,"name":"Item #2"},{"code":3,"name":"Item #3"}]
我已经阅读docs on template repeaters好几遍了,但仍然找不到我做错了什么。
如有任何帮助,我们将不胜感激!
这是我的自定义元素:
<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>
现在我正在使用它:
<x-myelement title="Hello Polymer"
items='[{"code":1,"name":"Item #1"},{"code":2,"name":"Item #2"},{"code":3,"name":"Item #3"}]'>
</x-myelement>
您需要将元素属性放入 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
属性 传递了一个字符串,导致您看到的错误。
我有一个呈现数组对象的简单模板。但是,它失败并显示以下消息:
[dom-repeat::dom-repeat]: expected array for `items`, found [{"code":1,"name":"Item #1"},{"code":2,"name":"Item #2"},{"code":3,"name":"Item #3"}]
数组按以下格式传入自定义元素的属性:
[{"code":1,"name":"Item #1"},{"code":2,"name":"Item #2"},{"code":3,"name":"Item #3"}]
我已经阅读docs on template repeaters好几遍了,但仍然找不到我做错了什么。
如有任何帮助,我们将不胜感激!
这是我的自定义元素:
<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>
现在我正在使用它:
<x-myelement title="Hello Polymer"
items='[{"code":1,"name":"Item #1"},{"code":2,"name":"Item #2"},{"code":3,"name":"Item #3"}]'>
</x-myelement>
您需要将元素属性放入 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
属性 传递了一个字符串,导致您看到的错误。