0
我想实现一个包含纸张选项卡的页面,每个选项卡根据名称初始值显示一个项目列表。我想知道数据绑定的最佳方式是什么。聚合物数据绑定:如何访问嵌套模板中的数据?
另外我有一些麻烦访问嵌套模板中的数据。当我点击不同的标签时,它不像我预期的那样工作。
下面是简化的代码:
//page
<paper-tabs selected="{{tab}}">
<template repeat="{{inital in pagination}}">
<paper-tab name="{{initial}}">
{{initial}}
</paper-tab>
</template>
</paper-tabs>
<items-field
tab="{{tab}}"
items="{{items}}">
</items-field>
//items-field
<polymer-element name="items-field" attributes="tab items">
<template>
<h2>h2 {{tab}}</h2>
<div>some other stuffs</div>
<template bind="{{items}}">
<h3>h3 {{tab}}</h3> <-- {{tab}} is undefined
<item-list
initial="{{tab}}"
</item-list>
</template>
</template>
<script>
Polymer({
tab: 'A'
)}
</script>
</polymer-element>
//item-list
<polymer-element name="items-list" attributes="initial">
<template>
<template repeat="{{item in items}}">
<item
hidden?="{{toHide(initial, item.name)}}">
</item>
</template>
</template>
<script>
Polymer({
ready: function() {
this.items = this.templateInstance.model;
console.log(this.initial); // <-- undefined
},
toHide: function (initial, name) {
if (initial === undefined ||
initial === name.charAt(0)) {
return false;
}
return true;
}
});
</script>
</polymer-element>
感谢@robdodson!我喜欢“元素就是模型”的想法。我的理解是:当我使用“绑定”时,该元素就是该模型;当我使用“属性”时,我向模型中注入了一些东西。最佳做法是什么,使用“绑定”还是使用“属性”? – DrXCheng 2015-02-24 20:08:55
绑定主要用于创建模板范围,并且,正如我所看到的那样,只是在键入时节省了时间。我会尽可能地让尽可能多的组件无状态和愚蠢。然后通过属性绑定将数据流向它们。 – robdodson 2015-02-24 22:27:02