if(!document.all){
//textContent->text
    Element.prototype.__defineGetter__('text',function(){return this.textContent===undefined?this.text:this.nodeType?this.textContent:undefined;});
    Element.prototype.__defineSetter__('text',function(txt){this.textContent=txt;});

//让firefox文本节点支持text属性
    Text.prototype.__defineGetter__('text',function(){return this.textContent===undefined?this.text:this.nodeType?this.textContent:undefined;});
    Text.prototype.__defineSetter__('text',function(txt){ this.textContent = txt;});
    
//serializeToString->xml 只读
    Element.prototype.__defineGetter__('xml',function(){return this.nodeType?(new XMLSerializer()).serializeToString(this):null;});

//addEventListener->attachEvent
    HTMLElement.prototype.attachEvent = function(ev, fn){
        ev = ev.toLowerCase();
        this.addEventListener(ev.indexOf('on')===0?ev.substr(2):ev, fn, false);
    };
//removeEventListener->detachEvent
    HTMLElement.prototype.detachEvent = function(ev, fn){
        ev = ev.toLowerCase();
        this.removeEventListener(ev.indexOf('on')===0?ev.substr(2):ev,fn);
    };
    
    if(self!=top){ //为移动xWin定义事件,document为xWin下的document
      var doXwinMv=false; //用于修正移动xWin后其中的文本会被选中的问题
      document.addEventListener('mousedown', function(ev){ mouseOffset={x:ev.pageX, y:ev.pageY} });
      document.addEventListener('mousemove', function(ev){ top.mouseMove(ev); });
      document.addEventListener('mouseup', function(ev){ top.mouseUp(ev);if(window.getSelection() && doXwinMv) window.getSelection().collapseToStart(); doXwinMv=false;});
    }
    
    //修正firefox下xWin背景色为黑色的问题
    //if(!window.getComputedStyle(document.documentElement,null)['backgroundColor']) document.documentElement.style.backgroundColor = '#fff';
    //document.documentElement.style.backgroundColor = '#fff';

//让firefox支持innerText属性
    HTMLElement.prototype.__defineGetter__("innerText",function(){
        var textRange = this.ownerDocument.createRange();
        textRange.selectNodeContents(this);
        return textRange.toString().replace(/\t\n/g,'');
    });
    HTMLElement.prototype.__defineSetter__("innerText",function(str){
        this.textContent = str;
    });
    
//修正firefox下firstChild lastChild获取到的是空白行文本节点的问题
    Element.prototype.__defineGetter__('firstChild',function(){
    var firstEleNode = firstNode = null;
    firstNode = this.childNodes[0];
    while (firstNode && firstNode.nodeType===3 && firstNode.nodeValue=='\n'){//若是空白行文本节点 则继续往后查找
        firstNode = firstNode.nextSibling;
    }
    firstEleNode = firstNode;
    return firstEleNode;
    });
    
    Element.prototype.__defineGetter__('lastChild',function(){
        var mIdx = this.childNodes.length-1;
        var lastNode = lastEleNode =null;
        lastNode = this.childNodes[mIdx];
        while(lastNode && lastNode.nodeType===3 && lastNode.nodeValue==='\n'){//若是空白行文本节点 继续往前查找
            lastNode = lastNode.previousSibling;
        }
        lastEleNode = lastNode;
        return lastEleNode;
    });
    
//后台返回xml文档后,遍历节点会遍历到空白行文本节点 所以需要这个方法先删除空白行文本节点 属性节点也是子节点??
    Element.prototype.__defineGetter__('delEmptyLineNode',function(){ //注意:document文档节点没继承该属性 document.documentElemnt根节点继承了该属性
        function delEmpty(node){
            var chNodes=node.childNodes, re=/^\s+$|\n|\t/m;
            for(var i=0, len=chNodes.length; i<len; i++){
                if (chNodes[i] && chNodes[i].nodeType===1){
                    if(chNodes[i].childNodes.length===1){ //叶子节点
                        
                    }else{ //非叶子元素节点 递归
                        delEmpty(chNodes[i]);
                    }
                }else if(chNodes[i] && chNodes[i].nodeType===3 && re.test(chNodes[i].nodeValue)){//空白文本节点
                    node.removeChild(chNodes[i]);
                    --i;
                }
            }
        }
        delEmpty(this);
        return this;
    });
    
    
//xmlNode.selectNodes()方法 只支持ie, 在当前xml节点下查找节点, Firefox下为Element原型定义同名属性
    Element.prototype.selectNodes = function(xpathStr){
        if(xpathStr.charAt(0)=='/') xpathStr="."+xpathStr;
        var snapshot = this.ownerDocument.evaluate(xpathStr, this, null, 7, null);
        var nodes = [];
        for(var i=0; i<snapshot.snapshotLength; i++){
            nodes.push(snapshot.snapshotItem(i));
        }
        return nodes;
    };
    
    Element.prototype.selectSingleNode = function(xpathStr){
        return this.selectNodes(xpathStr)[0];
    };
//ie怪异模式下 可以node.children(2)这样获取第3个子节点,firefox或ie9等现代浏览器都不行,firefox修改同名属性children为children()方法来兼容
//注:children重定义后,children[0]这样的写法将不可用
    Object.defineProperty(Element.prototype, 'children',{value:function(i){return this.delEmptyLineNode.childNodes[i];}, writable:true, enumerable:true, configurable:true});

//(new DOMParser())).parseFromString(xmlStr, 'text/xml') --> loadXML
    XMLDocument.prototype.loadXML = function(xmlStr){
            return (new DOMParser()).parseFromString(xmlStr,'text/xml');
    };

//让firefox支持insertAdjacentElement
    HTMLElement.prototype.insertAdjacentElement = function(sWhere, insEle){
        if(!insEle.nodeType) return;
        this.insertAdjacentHTML(sWhere,insEle.xml);
    };
//让firefox支持ie事件对象的相关属性
//-- returnValue --
    Event.prototype.__defineSetter__("returnValue", function(b){
        if(!b) this.preventDefault();
        return b
    });
//-- cancelBubble --
    Event.prototype.__defineSetter__("cancelBubble", function(b){
        if(b) this.stopPropagation();
        return b;
    });
//--- srcElement ---
    Event.prototype.__defineGetter__("srcElement", function(){
        var node = this.target;
        while(node.nodeType !== 1) node = node.parentNode;
        return node;
    });
//--- fromElement ---
    Event.prototype.__defineGetter__("fromElement", function(){
        var node;
        if(this.type == 'mouseover'){ node = this.relatedTarget;}
        if(this.type == 'mouseout'){ node = this.target; }
        if(!node) return null;
        while(node.nodeType!=1){ node = node.parentNode; }
        return node;
    });
//--- toElement ---
    Event.prototype.__defineGetter__("toElement", function(){
        var node;
        if(this.type == 'mouseover'){ node = this.target; }
        if(this.type == 'mouseout' ){ node = this.relatedTarget; }
        if(!node) return null;
        while(node.nodeType!=1){ node = node.parentNode; }
        return node;
    });

//让firefox下table支持moveRow方法
    HTMLElement.prototype.moveRow = function(srcIdx, targetIdx){
        var re = /^(table|tbody|tfoot|thead)/i;
        if(!re.test(this.nodeName) || srcIdx === targetIdx) return;
        var pNode, srcR,targetR;
        pNode = this;
        if(this.nodeName.toLowerCase() === 'table') pNode = this.getElementsByTagName('tbody')[0]; //firefox 自动插入tbody
        //targetIdx<srcIdx 行往前面移 直接pNode.insertBefore()即可
        srcR = pNode.rows[srcIdx];
        targetR = pNode.rows[targetIdx];
        if(!srcR || !targetR) return; //索引范围以外 则返回
        targetRnext = pNode.rows[targetIdx+1] || null;
        if(targetIdx < srcIdx) pNode.insertBefore(srcR, targetR);
        if(targetIdx > srcIdx) pNode.insertBefore(srcR, targetRnext);
    };

//让firefox下的styleSheet对象支持rules属性    
    CSSStyleSheet.prototype.__defineGetter__('rules', function(){return this.cssRules});

//让firefox支持currentStyle 注意color样式值会转换为 rgb(233,22,22)的形式
    HTMLElement.prototype.__defineGetter__('currentStyle',function(){return window.getComputedStyle(this,null);});

//firefox createElementX
    HTMLDocument.prototype.createElementX = function (tag){
        var re=/^<.+>$/;
        if(re.test(tag)){ //<p ...></p> < ...>
            try{
                var tmpDiv = this.createElement('div'); //临时div
                tmpDiv.innerHTML = tag;
                return tmpDiv.firstChild;
            }catch(err){alert(err.message);}
        }else{ // p, div...
            try{
                return document.createElement(tag);
            }catch(e){alert(e.message)}
        }
    }
    
}//For Firefox End

原型扩展的方法解决IE和Firefox的Js兼容问题的更多相关文章

  1. JS高级---原型的引入,原型添加的方法解决数据共享

    原型的引入:解决:通过构造函数创建对象带来的问题,即浪费内存(一个对象开一个内存,多个对象开多个内存) 通过原型来添加方法,解决数据共享,节省内存空间 <script> function ...

  2. 解决selenium和FireFox版本不兼容问题

    相信很多同学刚接触selenium时,在Eclipse中打开fireFox浏览器时会报错:org.openqa.selenium.firefox.NotConnectedException: Unab ...

  3. 解决selenium与firefox版本不兼容问题

    Python环境下类比 个人使用 32位环境 Python 2.7.12 Selenium 2.53.6 Firefox 47.01 安装selenium可用pip选择对应版本,参考另一教程. 因为在 ...

  4. IE和FireFox中JS兼容之event .

    event对象 IE 中可以直接使用 event 对象,而 FF 中则不可以,解决方法之一如下:var theEvent = window.event || arguments.callee.call ...

  5. [转]IE和FireFox中JS兼容之event .

    转载于:http://blog.csdn.net/jiachunfeng/article/details/6448186 http://justcoding.iteye.com/blog/587876 ...

  6. ORA-01652:无法通过128(在表空间temp中)扩展temp段 解决方法

    ORA-01652:无法通过128(在表空间temp中)扩展temp段 解决方法 (2016-10-21 16:49:53)   今天在做一个查询的时候,报了一个"ORA-01652无法通过 ...

  7. (转)再不用担心DataRow类型转换和空值了(使用扩展方法解决高频问题)

    再不用担心DataRow类型转换和空值了(使用扩展方法解决高频问题) XML文档操作集锦(C#篇) webapi文档描述-swagger

  8. call()和原型继承的方法

    1.call() call()方法接受两个参数,obj和arg 比如functionA.call(obj,arg)   就是说现在运行(执行)functionA这个方法,但是functionA里面的方 ...

  9. 在Function对象上扩展method方法

    ;(function() { /** * 在Function对象上扩展method方法 * @param {String} name 扩展的方法名称 * @param {Function} callb ...

随机推荐

  1. python 整数和浮点数

    整数和浮点数 Python支持对整数和浮点数直接进行四则混合运算,运算规则和数学上的四则运算规则完全一致. 基本的运算: 1 + 2 + 3 # ==> 6 4 * 5 - 6 # ==> ...

  2. SQL Server 2012学习笔记 2 Server Core中命令行安装SQL

    Setup.exe /qs /ACTION=Install /FEATURES=SQLEngine,Replication /INSTANCENAME=MSSQLSERVER /SQLSVCACCOU ...

  3. [非技术参考]C#重写ToString方法

    C# 中的每个类或结构都隐式继承 Object 类. 因此,C# 中的每个对象都会获得 ToString 方法,此方法返回该对象的字符串表示形式. 例如,所有 int 类型的变量都有一个 ToStri ...

  4. 对Java的Map的Value字段进行排序

    构造TreeMap可以指定Comparator,但是不能对value字段进行排序.如果有需求对Value字段排序,例如map存放的是单词,单词出现次数,怎么按单词次数排序呢? 可以先将map中的key ...

  5. [翻译]如何用YII写出安全的WEB应用

    前言 虽然本文是基于YII1.1,但其中提到的安全措施适用于多数web项目安全场景,所以翻译此文,跟大家交流.原文地址. 目录 安全基本措施... 2 验证与过滤用户的输入信息... 2 原理... ...

  6. MySQL 基础学习

    http://www.w3school.com.cn/sql/ 1.limit x,y 或 limit z  :选取从x开始的y条数据  或  选取最开始的 z条数据 , 2.like '%N%' : ...

  7. 1.PHP 教程_PHP 简介

    PHP是服务器端脚本语言. 在学习之前,您需要对以下知识有基本的了解: HTML css PHP是什么? PHP代表PHP:Hypertext Preprocessor PHP是一种使用广泛的开源的脚 ...

  8. gmpy2安装使用方法

    GMP(GNU Multiple Precision Arithmetic Library,即GNU高精度算术运算库),它是一个开源的高精度运算库,其中不但有普通的整数.实数.浮点数的高精度运算,还有 ...

  9. Javascript 设计模式笔记

    设计模式太多了 还有些模式概念非常接近(比如观察者 中介者 和 事件发布/订阅模式) 构造器模式 var newObject = {} var newObject = new XXX(); 模块模式 ...

  10. ZOJ Monthly, March 2013

    A题 题目大意:给出一棵树,一开始节点值均为0,先要求完成在线操作:将某子树所有节点值取反,或者查询某子树总点权. 题解:很基础的线段树题,既然两个操作都是子树操作,那么就先树链剖分一下,将子树操作转 ...