點評:隨著科技的日新月異,各種瀏覽器層出不窮,最近的項目要求對同時支持IE和FireFox等各種瀏覽器,為此深受其苦,尤其是對于我這個習慣了使用諸如:"event.srcElement"、"outerHTML"、"parentElement"的人來說。許多在IE中使用起來得心應手的對象和方法,在W3C標準面
代碼很簡單,如下:
復制代碼
代碼如下: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());
});