Element transclusion

岁酱吖の 提交于 2019-12-03 20:31:12
ebidel

In Shadow DOM land, this is called distribution. To distribute light DOM nodes into the shadow dom, you use <content> insertion points.

http://www.polymer-project.org/platform/shadow-dom.html#shadow-dom-subtrees

It's quite literally a way to render nodes from light dom into placeholders in the shadow dom. If you want to do tricky things with the my-header/my-header-item title/name attributes, you can do something like this:

<polymer-element name="my-header">
  <template>
    <ul>
      <template repeat="{{item in items}}">
        <li>{{item.name}}</li>
      </template>
    </ul>
    <content id="c" select="my-header-item"></content>
  </template>
  <script>
   Polymer('my-header', {
     domReady: function() {
       this.items = [].slice.call(this.$.c.getDistributedNodes());
     }
   });
  </script>
</polymer-element>

Demo: http://jsbin.com/hupuwoma/1/edit

I have a more full-fledged tabs demo does this setup over on https://github.com/ebidel/polymer-experiments/blob/master/polymer-and-angular/together/elements/wc-tabs.html.

While admittedly I'm also new to polymer - I think I can answer this.

You should be able to substitute the value of an attribute into the template using the double-mustache syntax e.g.

<h1>{{title}}</h1>

See http://www.polymer-project.org/docs/start/creatingelements.html#publishing

In addition to this you can also substitute the content of a tag. For example if instead of using the "name" attribute in your my-header-item tag you instead had something like this...

<my-header-item>Item 1</my-header-item>

then you could substitute "Item 1" like this:

<li><content></content></li>

See http://www.polymer-project.org/platform/shadow-dom.html for this usage

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!