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

本文共 1142 字,大约阅读时间需要 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有时也可以,目前这个问题还得研究一下,后面再更新。

恭喜你看完了。

转载地址:http://ybrda.baihongyu.com/

你可能感兴趣的文章
如何申请开通微信多客服功能
查看>>
Sr_C++_Engineer_(LBS_Engine@Global Map Dept.)
查看>>
非监督学习算法:异常检测
查看>>
jquery的checkbox,radio,select等方法总结
查看>>
Linux coredump
查看>>
Ubuntu 10.04安装水晶(Mercury)无线网卡驱动
查看>>
我的友情链接
查看>>
nginx在reload时候报错invalid PID number
查看>>
神经网络和深度学习-第二周神经网络基础-第二节:Logistic回归
查看>>
ElasticSearch 2 (32) - 信息聚合系列之范围限定
查看>>
VS2010远程调试C#程序
查看>>
[MicroPython]TurniBit开发板DIY自动窗帘模拟系统
查看>>
Python3.4 12306 2015年3月验证码识别
查看>>
从Handler.post(Runnable r)再一次梳理Android的消息机制(以及handler的内存泄露)
查看>>
windows查看端口占用
查看>>
Yii用ajax实现无刷新检索更新CListView数据
查看>>
JDBC的事务
查看>>
Io流的概述
查看>>
App 卸载记录
查看>>
JavaScript变量和作用域
查看>>