我开发了一种聚合物元素。在这个元素中,我收到了一些参数。当我将 [value array] 参数传递给元素时不起作用。但是,如果我手动设置值,它就可以工作。
这是聚合物元素头:
<polymer-element name="nick-viewer-card" attributes="program details link chart">
这是代码问题:
<div class="heading" on-click="{{ toggle }}">{{ program }}</div>
<core-collapse id="collapse">
<div class="content">
<div>{{ details }}</div>
<div><a href="{{ link }}"> more details</a></div>
<div>{{ chart }}</div>
<chart-pie
width="150"
height="150"
values="[30, 50, 100, 40, 120]"> <!-- {{ chart }} -->
</chart-pie>
</div>
</core-collapse>
这是调用:
<nick-viewer-card program="{{gsx$program.$t}}" details="{{gsx$details.$t}}"
link="{{gsx$link.$t}}" chart="{{gsx$chart.$t}}"></nick-viewer-card>
我收录了#mudasobwa建议:
<div>{{ chart }}</div>
<div><a href="{{ link }}"> more details</a></div>
<chart-pie
width="150"
height="150"
values="{{ chart }}">
</chart-pie>
这是输出:
并且控制台错误与类型有关:
答案 0 :(得分:2)
TL; DNR 数组不是HTML的内置类型。你应该传递像"[1,2,3]"
这样的字符串而不是数组本身([1,2,3]
),这些字符串会透明地转换为字符串'1,2,3'
(注意周围没有方括号。)
让我们简化您的代码片段以找出问题。
首先,我们将定义假的chart-pie
组件,以确保不会引发问题。
<polymer-element name="chart-pie-fake" attributes="values">
<template>
{{ values }}
</template>
<script>
Polymer({});
</script>
</polymer-element>
现在我们将尝试将数组和字符串传递给元素:
<div>{{ chart }}</div>
<chart-pie-fake
values="{{ chart }}"> <!-- STRING / ARRAY -->
</chart-pie-fake>
现在比较输出,我们将看到,传递参数的正确方法是:
<script>
Polymer({
chart_will_fail: [30, 50, 100, 40, 120],
chart: '[30, 50, 100, 40, 120]'
});
</script>
不幸的是,内部Array#toString()
会在数组周围放下方括号。因此,要使其工作,您需要将数组转换为字符串本身。例如。 '[' + myArray.join(',') + ']'
。
UPD :我还不能理解原因,但图表饼干的情况下图表值的字符串应该显式地转换为数组:< / p>
<chart-pie
width="150"
height="150"
values="{{ chart | arrayize }}"> <!-- OMG -->
</chart-pie>
...
Polymer({
arrayize: function(el) {
return JSON.parse(el);
}
});