Dom-Repeat无法与大对象(Base64编码图像)一起使用



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

但是,当我以这种方式生成DOM重复时,每个项目都将不确定。我认为这是因为对象在渲染DOM重复时太大而无法读取。

这是一个显示问题的片段。

<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图片已经加载。(我如何解决此问题?

没有理由不起作用。尝试下面的摘要

<!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>

最新更新