dom-repeat不适用于大对象(base64编码图像)

时间:2017-06-28 09:56:47

标签: javascript html polymer

我正在使用一个对象列表生成一个dom-repeat,每个对象都有一个包含非常大的base64编码图像的imgUrl键。

然而,当我以这种方式生成dom-repeat时,每个项目都将是未定义的。我假设这是因为渲染dom-repeat时对象太大而无法读取。

以下是显示此问题的摘录。

<template is="dom-repeat" items="{{myitems}}">
  <p>{{item.name}}</p>
  <img src="[[item.imgUrl]]"/>
</template>

<script>
  // ...

  // Doesn't work:
  var list = [];
  myobj = {
    name: "Hello",
    imgUrl: " /*BASE64 string here*/ "
  }
  list.push(myobj);
  this.set('myitems', list);

  //Works:

  var list = [];
  myobj = {
    name: "Hello",
    imgUrl: ""
  }
  list.push(myobj);
  this.set('myitems', list);

  // ...

</script>

我需要dom-repeat才能渲染,直到我知道整个base64图片已加载。 (怎么样)我可以解决这个问题吗?

1 个答案:

答案 0 :(得分:1)

没有理由不工作。试试下面的代码段

<!doctype html>
<head>
  <base href="https://polygit.org/polymer+1.7.1/components/">
  <script src="webcomponentsjs/webcomponents-lite.js"></script>

  <script>
    // Setup Polymer options
    window.Polymer = {
      dom: 'shadow'
    };
  </script>

  <link rel="import" href="polymer/polymer.html">
</head>

<body>

  <my-elem></my-elem>

  <dom-module id="my-elem">
    <template>

      <template is="dom-repeat" items="{{myitems}}">
        <p>{{item.name}}</p>
        <img src$="[[item.imgUrl]]" />
      </template>

    </template>
    <script>
      Polymer({
        is: 'my-elem',

        ready: function () {
          var list = [];
          var myobj = {
            name: "Hello",
            imgUrl: ""
          };
          list.push(myobj);

          var myobj2 = {
            name: "Hello2",
            imgUrl: ""
          };

          list.push(myobj2);

          this.set('myitems', list);
        }
      });
    </script>
  </dom-module>
</body>