html5中文学习网

您的位置: 首页 > html5教程 > 入门教程 » 正文

解决Firefox下不支持outerHTML问题代码分享_html5教程技巧

[ ] 已经帮助:人解决问题
点评:随着科技的日新月异,各种浏览器层出不穷,最近的项目要求对同时支持IE和FireFox等各种浏览器,为此深受其苦,尤其是对于我这个习惯了使用诸如:"event.srcElement"、"outerHTML"、"parentElement"的人来说。许多在IE中使用起来得心应手的对象和方法,在W3C标准面

代码很简单,如下:BHAHTML5中文学习网 - HTML5先行者学习网


复制代码
代码如下:
BHAHTML5中文学习网 - HTML5先行者学习网
var pro = window.HTMLElement.prototype;BHAHTML5中文学习网 - HTML5先行者学习网
pro.__defineGetter__("outerHTML", function(){BHAHTML5中文学习网 - HTML5先行者学习网
var str = "<" + this.tagName;BHAHTML5中文学习网 - HTML5先行者学习网
var a = this.attributes;BHAHTML5中文学习网 - HTML5先行者学习网
for(var i = 0, len = a.length; i < len; i++){BHAHTML5中文学习网 - HTML5先行者学习网
if(a[i].specified){BHAHTML5中文学习网 - HTML5先行者学习网
str += " " + a[i].name + '="' + a[i].value + '"';BHAHTML5中文学习网 - HTML5先行者学习网
}BHAHTML5中文学习网 - HTML5先行者学习网
}BHAHTML5中文学习网 - HTML5先行者学习网
if(!this.canHaveChildren){BHAHTML5中文学习网 - HTML5先行者学习网
return str + " />";BHAHTML5中文学习网 - HTML5先行者学习网
}BHAHTML5中文学习网 - HTML5先行者学习网
return str + ">" + this.innerHTML + "</" + this.tagName + ">";BHAHTML5中文学习网 - HTML5先行者学习网
});BHAHTML5中文学习网 - HTML5先行者学习网
pro.__defineSetter__("outerHTML", function(s){BHAHTML5中文学习网 - HTML5先行者学习网
var r = this.ownerDocument.createRange();BHAHTML5中文学习网 - HTML5先行者学习网
r.setStartBefore(this);BHAHTML5中文学习网 - HTML5先行者学习网
var df = r.createContextualFragment(s);BHAHTML5中文学习网 - HTML5先行者学习网
this.parentNode.replaceChild(df, this);BHAHTML5中文学习网 - HTML5先行者学习网
return s;BHAHTML5中文学习网 - HTML5先行者学习网
});BHAHTML5中文学习网 - HTML5先行者学习网
pro.__defineGetter__("canHaveChildren", function(){BHAHTML5中文学习网 - HTML5先行者学习网
return !/^(area|base|basefont|col|frame|hr|img|br|input|isindex|link|meta|param)$/.test(this.tagName.toLowerCase());BHAHTML5中文学习网 - HTML5先行者学习网
});BHAHTML5中文学习网 - HTML5先行者学习网
BHAHTML5中文学习网 - HTML5先行者学习网

BHAHTML5中文学习网 - HTML5先行者学习网
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助