聚合物:创建一个" general"自定义元素

时间:2015-02-10 15:08:44

标签: javascript polymer web-component custom-element

我正在尝试使用属性构建一个元素,该元素将指定应该取代此元素的元素。

我有一个3d-card翻转元素,我在index.html中用于此目的,定义为:

<html>
    <head>
        <script src="bower_components/webcomponentsjs/webcomponents.js">
        </script>
        <link rel="import" href="elements/general-element.html">
    </head>
    <body>
        <general-element 
            name="card-flip" 
            address="elements/card-flip.html">
            <front>
                FRONT
            </front>
            <back>
                BACK
            </back>
        </general-element>
    </body>
</html>

这里定义了general-element.html:

<link rel="import" 
    href="../bower_components/polymer/polymer.html">
<polymer-element name="general-element" attributes="name address">
    <template>
        <div id="element_here">
        </div>
    </template>
    <script>

      function addElementToDOM( element_name, _that ) {
          var elem = _that.shadowRoot.querySelector( "#element_here" );
          add_elem = document.createElement( element_name );
          elem.appendChild( add_elem );
      }

        Polymer ( 'general-element', {
          ready: function() {
              if ( 
                  ( this.address != undefined ) && 
                  ( this.name != undefined ) ) {

                  Polymer.import( 
                      [this.address], 
                      addElementToDOM( this.name, this )
                  );
              }
          }
        } );
    </script>
</polymer-element>

警告:输出是一个空白,控制台中出现错误,说明卡片翻转的属性在Polymer升级元素之前是数据绑定的。这可能会导致绑定类型不正确。

这可以通过任何方式实现吗?

1 个答案:

答案 0 :(得分:4)

很难说你想要实现什么,但我会在你的代码中指出一些问题并提供工作版本paper-button而不是flip-card(因为我没有代码{ {1}}。)

TL; DR 实时预览:http://plnkr.co/edit/yO865EkclZAsWBhzVSU4?p=preview

  1. 您的代码的主要问题是您调用函数flip-card而不是将其作为Polymer.import请求的回调传递。 addElementToDOM可以。

  2. 您对通常禁止的自定义元素(如function() { addElementToDOM(...); }front)使用无连字符的名称。请使用我的示例中的虚线。

  3. 您的功能无缘无故地被污染到全局空间中。我把它放在一个元素中。

  4. 您可能希望将自定义back放在flip-cardfront之间,但没有back标记的痕迹 在你的模板里面。

  5. 您试图以不正当的方式访问content select='front/back'。您可能需要查看shadowRoot函数,但在这种情况下,使用命名约定并简单地通过getDistributedNodes来处理元素会更容易。

  6. 您应该明确指定polyfill的this.$.elementHere来处理未解决的问题。

  7. 工作代码:

    <body unresolved>

    我敢打赌,你的代码可以通过应用修复#1来工作,但我强烈建议你修复其他故障。希望它有所帮助。

    P.S。为什么在地球上你需要动态导入你的元素?简单的

    有什么问题
    <!doctype html>
    <html>
    <head>
      <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
      <title>Add paper button</title>
      <script src="https://www.polymer-project.org/components/webcomponentsjs/webcomponents.js"></script>
      <link href="https://www.polymer-project.org/components/polymer/polymer.html" rel="import"> 
    </head>
    
    <body unresolved>
      <polymer-element name="general-element" attributes="name address">
        <template>
          <content select='my-front'></content>
          <div id="elementHere">
          </div>
          <content select='my-back'></content>
        </template>
        <script>
          Polymer ({
            addElementToDOM: function ( element_name ) {
              var elem = this.$.elementHere;
              add_elem = document.createElement( element_name );
              add_elem.appendChild(document.createTextNode('¡Hola!'));
              elem.appendChild( add_elem );
            },
    
            domReady: function() {
              if ( this.address && this.name ) {
                var self = this;
                Polymer.import( 
                  [self.address], 
                  function() { self.addElementToDOM( self.name ); }
                );
              }
            }
          });
        </script>
      </polymer-element>
      <general-element 
          name="paper-button" 
          address="https://www.polymer-project.org/components/paper-button/paper-button.html">
          <my-front>
              FRONT
          </my-front>
          <my-back>
              BACK
          </my-back>
      </general-element>
    </body>
    </html>