嵌套聚合物元素之间的数据绑定

前端之家收集整理的这篇文章主要介绍了嵌套聚合物元素之间的数据绑定前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
假设我有两个不同的聚合物元素

一个应该使用内容占位符嵌入其他内部.
这两个嵌套的聚合物元素之间是否可以进行数据绑定?

我试过,但我不能让它上班:http://jsbin.com/IVodePuS/11/

根据http://www.polymer-project.org/articles/communication.html#binding,聚合物元素之间的数据绑定应该起作用(在这些例子中,它们在模板标签内完成,而不使用内容占位符).

更新:

Scott Miles澄清说,数据绑定只适用于模板级别.
然而,在我的情况下,我不会事先知道确切的模板,但我想允许我的parent-element的用户指定它应该包含哪个子元素(前提是有不同的子元素.
我认为这个问题与这个问题有关:Using template defined in light dom inside a Polymer element

我更新了下面的例子来强调他的:

  1. <polymer-element name="parent-element" >
  2. <template >
  3. <div>Parent data: {{data1}} </div>
  4. <content />
  5. </template>
  6. <script>
  7. Polymer('parent-element',{
  8. data1 : '',ready: function() {
  9. this.data='parent content';
  10. }
  11. });
  12.  
  13. </script>
  14. </polymer-element>
  15.  
  16. <polymer-element name="child-element" attributes="data2">
  17. <template>
  18. <div>Parent data: {{data2}} </div>
  19. </template>
  20. <script>
  21. Polymer('child-element',{
  22. data2 : '',ready: function() {
  23. }
  24. });
  25. </script>
  26. </polymer-element>
  27.  
  28. <polymer-element name="child2-element" attributes="data2">
  29. <template>
  30. <div>Parent data: {{data2}} </div>
  31. </template>
  32. <script>
  33. Polymer('child2-element',ready: function() {
  34. }
  35. });
  36. </script>
  37. </polymer-element>

用户可以选择要嵌入的子元素:

  1. <parent-element data1 = "test">
  2. <child-element data2="{{data1}}"/>
  3. </parent-element>
  4.  
  5. <parent-element data1 ="test" >
  6. <child2-element data2="{{data1}}"/>
  7. </parent-element>

解决方法

我发现唯一的解决方法添加更改观察器并使用getDistributedNodes()来获取子元素,并手动将data2设置为数据:

  1. <polymer-element name="parent-element" >
  2. <template >
  3. <div>Parent data: {{data}} </div>
  4. <content id="content"/>
  5. </template>
  6. <script>
  7. Polymer('parent-element',{
  8. data : '',ready: function() {
  9. this.data='parent content';
  10. },dataChanged : function() {
  11. contents = this.$.content.getDistributedNodes();
  12. if (contents.length > 0) {
  13. contents[0].data2 = this.data;
  14. }
  15. },});
  16.  
  17. </script>
  18. </polymer-element>

解决方法

聚合物数据绑定通过将模型附加到整个子树来进行.

你写了:

  1. <parent-element>
  2. <child-element data2="{{data}}"/>
  3. </parent-element>

这意味着parentNode提供绑定模型的规则.但现在想象你想写:

  1. <parent-element>
  2. <div>
  3. <child-element data2="{{data}}"></child-element>
  4. </div>
  5. </parent-element>

现在你有一个问题.

相反,在聚合物示例中,您将注意到{{}}(几乎总是)在模板内部.例如,如果我定义:

  1. <polymer-element name="host-element" attributes="data" noscript>
  2. <template>
  3. <parent-element data1="{{data}}">
  4. <child-element data2="{{data}}"></child-element>
  5. </parent-element>
  6. </template>
  7. </polymer-element>

现在,我有一个模型上下文(host-element),可以在模板描述的整个子树中将东西绑定在一起.

请注意,我不需要属性=“数据”,以使其工作.我补充说,所以host-element公开数据,我可以这样做:

  1. <host-element data="test"></host-element>

http://jsbin.com/IVodePuS/15/edit

猜你在找的HTML相关文章