欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

解决Firefox下不支持outerHTML问题代码分享

程序员文章站 2023-11-05 23:15:10
随着科技的日新月异,各种浏览器层出不穷,最近的项目要求对同时支持IE和FireFox等各种浏览器,为此深受其苦,尤其是对于我这个习惯了使用诸如:"event.srcElement"、"outerHTML"、"p... 14-06-04...

代码很简单,如下:


复制代码
代码如下:

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());
});