博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
前端组件化Polymer入门教程(4)——自定义元素
阅读量:5038 次
发布时间:2019-06-12

本文共 1190 字,大约阅读时间需要 3 分钟。

除了上一篇说到的创建自定义元素方法以外,还可以通过原生JS来创建,当你需要动态的创建元素时可以通过这种方式。

template.html

index.html

    
Document

857662-20160929170457094-1647516469.png

created: function() {``this.textContent = 'My element!';}

当创建这个元素的时候,created会被执行,关于更多这方面的信息我们会在生命周期篇详细说明。

var el1 = document.createElement('my-element');var el2 = new MyElement();var el3 = new MyElement();document.getElementById('box').appendChild(el2);document.getElementById('box').appendChild(el3);

用new创建MyElement实例,createElement只是创建并不会被添加

857662-20160929161133563-1781471908.png

如果在实例化的时候你想传递参数可以通过添加一个factoryImpl方法。

857662-20160929163215516-442786749.png

当MyElement被实例化的时候factoryImpl会接受这些参数,并且执行。另外如果你想自定义方法,可以这样。

857662-20160929163434641-771763395.png

默认情况下msg是不会执行的,需要我们手动调用。

扩展原生HTML元素

template.html

extends需要扩展的元素,created被创建的时候,通过js的createElement创建或者HTML添加都会执行这个方法。

index.html

在需要被扩展的元素上添加一个is属性。

857662-20160929164229110-2099941113.png

以上是直接通过HTML的方式添加的,如果需要通过js来操作可以通过下面的方法。

template.html

857662-20160929165135797-467767422.png

注意:目前只支持扩展input或button,其他元素或许以后会支持。

如果你想在页面加载完毕以后再执行可以这样写。

template.html

index.html

    
Document

当文档中的所有输入都已完成加载时才会调用HTMLImports.whenReady函数。

整篇文章下来,发现创建元素时没有用new有时也可以,目前这个问题还得研究一下,后面再更新。

恭喜你看完了。

转载于:https://www.cnblogs.com/pssp/p/5920530.html

你可能感兴趣的文章
LeetCode 132. 分割回文串 II(Palindrome Partitioning II)
查看>>
关于PHP的引用赋值
查看>>
软件工程第三次作业
查看>>
默慈金数
查看>>
24、java操作xml方法
查看>>
hdu 1879 继续畅通project
查看>>
java 使用LinkedList模拟一个堆栈或者队列数据结构
查看>>
调整GDI显示方向
查看>>
node 单个表加条件查询
查看>>
单例模式
查看>>
Sublime Text 3 绝对神器
查看>>
enableEventValidation
查看>>
[GO]ticker的使用
查看>>
Linux限制端口
查看>>
C++变量初始化
查看>>
node学习心得
查看>>
顺序表存储空间连续问题
查看>>
牛客练习赛46 E 华华和奕奕学物理 (树状数组)
查看>>
JSP实现在项目在网页上查询
查看>>
zencart 网站空白的解决方案
查看>>