Polymer elemento <chart-pie>和binding </chart-pie>

时间:2015-01-29 22:05:52

标签: javascript polymer pie-chart web-component

我开发了一种聚合物元素。在这个元素中,我收到了一些参数。当我将 [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>

这是输出:

enter image description here

并且控制台错误与类型有关: enter image description here

1 个答案:

答案 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);
  }
});