我正在尝试访问我在自己的聚合物元素中编写的html,但它不起作用。我怎样才能做到这一点?
的index.html
<my-element> content I am trying to access </my-element>
我-element.html
<polymer-element name='my-element'>
<template>
<content id='content'></content>
</template>
<script>
Polymer({
ready: function(){
console.log('html: '+this.$.content.innerHTML);
}
});
</script>
</polymer-element>
控制台
html:
答案 0 :(得分:2)
不幸的是,该实现将内容节点插入content
的兄弟,而不是嵌套节点。也就是说,在一切准备就绪后,文档的结构将如下所示:
<content id='content'></content>
content I am trying to access
不像你可能期待的那样:
<!-- THAT IS NOT HOW IT’S COMPOSED -->
<content id='content'>content I am trying to access</content>
幸运的是,您仍然可以在模板上下文中访问childNodes
:
Polymer({
domReady: function() {
var content = '';
this.childNodes.array().forEach( function(el) {
content += el.textContent; // do whatever you want here
});
console.log(content);
}
});
//⇒ content I am trying to access
希望它有所帮助。