博客
关于我
强烈建议你试试无所不能的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/

你可能感兴趣的文章
tomcat7 https 成功测试
查看>>
char* 和char[]的差别
查看>>
(转)java中对集合对象list的几种循环访问总结
查看>>
angularjs之$timeout指令
查看>>
netty 的 Google protobuf 开发
查看>>
Java中23种经典设计模式详解
查看>>
Android如何调用第三方SO库(转)
查看>>
创新学分材料
查看>>
ZA7783:MIPI转LVDS/MIPI转RGB888/RGB转LVDS
查看>>
十大经典数据挖掘算法(9) 朴素贝叶斯分类器 Naive Bayes
查看>>
cobbler配置解析
查看>>
linux下磁盘进行分区、文件系统创建、挂载和卸载(转)
查看>>
sublime快捷方式和node.js
查看>>
Unity的DrawCall
查看>>
leetcode -day19 Convert Sorted List to Binary Search Tree
查看>>
linux 命令总结(转载)
查看>>
ScrollView 嵌套ListView 幻灯冲突,和显示不全
查看>>
[lua, mysql] 将多条记录数据组合成一条sql插入语句(for mysql)
查看>>
Linux 编程学习笔记----命令行参数处理
查看>>
自动检查点(Automatic Checkpointing)
查看>>