FF的outerHTML

一种网上常见的方法是这样的:

1. var pro = window.HTMLElement.prototype;
2. pro.__defineGetter__("outerHTML", function(){
3. var str = "<" + this.tagName;
4. var a = this.attributes;
5. for(var i = 0, len = a.length; i < len; i++){
6. if(a[i].specified){
7. str += " " + a[i].name + '="' + a[i].value + '"';
8. }
9. }
10. if(!this.canHaveChildren){
11. return str + " />";
12. }
13. return str + ">" + this.innerHTML + "</" + this.tagName + ">";
14. });
15. pro.__defineSetter__("outerHTML", function(s){
16. var r = this.ownerDocument.createRange();
17. r.setStartBefore(this);
18. var df = r.createContextualFragment(s);
19. this.parentNode.replaceChild(df, this);
20. return s;
21. });
22. pro.__defineGetter__("canHaveChildren", function(){
23. return !/^(area|base|basefont|col|frame|hr|img|br|input|isindex|link|meta|param)$/.test(this.tagName.toLowerCase());
24. });



不过感觉getter实现方法应该这样:clone当前div,放入一个tempdiv中,然后取tempdiv的innerHTML这样效率应该高很多

setter实现方法:也可以放入div中循环appendChild节点,不过效率没有createContextualFragment这种高


没深入研究,欢迎指导
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值