解决Firefox下不支持outerHTML问题代码分享
解决Firefox下不支持outerHTML问题代码分享
发布时间:2016-12-27 来源:查字典编辑
摘要:代码很简单,如下:varpro=window.HTMLElement.prototype;pro.__defineGetter__("out...

代码很简单,如下:

var pro = window.HTMLElement.prototype;

pro.__defineGetter__("outerHTML", function(){

var str = "<" + this.tagName;

var a = this.attributes;

for(var i = 0, len = a.length; i < len; i++){

if(a[i].specified){

str += " " + a[i].name + '="' + a[i].value + '"';

}

}

if(!this.canHaveChildren){

return str + " />";

}

return str + ">" + this.innerHTML + "</" + this.tagName + ">";

});

pro.__defineSetter__("outerHTML", function(s){

var r = this.ownerDocument.createRange();

r.setStartBefore(this);

var df = r.createContextualFragment(s);

this.parentNode.replaceChild(df, this);

return s;

});

pro.__defineGetter__("canHaveChildren", function(){

return !/^(area|base|basefont|col|frame|hr|img|br|input|isindex|link|meta|param)$/.test(this.tagName.toLowerCase());

});

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新HTML5教程学习
热门HTML5教程学习
网页设计子分类