喜悦国际村 
» 游客:  注册 | 登录 | 搜索 | 统计 | 喜悦证交所 | 帮助

RSS 订阅当前论坛  

【村长请吃饭啊】 ---北京诚聘--- 【你还在犹豫吗?】

上一主题 下一主题
     
标题: 怎么改造代码以在FireFox下实现?  
 
diekiss
金牌会员
Rank: 6Rank: 6
高级会员


UID 18243
精华 0
积分 1377
帖子 1357
金钱 1377 喜悦币
威望 0
人脉 0
阅读权限 70
注册 2003-2-3
来自 狮山俊景
状态 在线
怎么改造代码以在FireFox下实现?

文字我就不重复了,请参见:
http://www.blueidea.com/bbs/News ... lp=1&id=1945973
2005-4-27 12:50 PM#1
查看资料  访问主页  发短消息  QQ  顶部
 
ALPS (km3945)
版主
Rank: 7Rank: 7Rank: 7
版主


UID 46538
精华 0
积分 1293
帖子 1261
金钱 1293 喜悦币
威望 0
人脉 0
阅读权限 100
注册 2004-11-8
状态 在线
[推荐阅读] 这种情况数据表应该怎样设计?
给moz添加ie方法和属性
代码目的,让跨浏览器编程变的跟在ie下编程一样

<?php
<script language="JavaScript" type="Text/JavaScript">
<!--
if(
window.Event){// 修正Event的DOM
    /*
                                IE5        MacIE5        Mozilla        Konqueror2.2        Opera5
    event                        yes        yes            yes            yes                    yes
    event.returnValue            yes        yes            no            no                    no
    event.cancelBubble            yes        yes            no            no                    no
    event.srcElement            yes        yes            no            no                    no
    event.fromElement            yes        yes            no            no                    no
    
    */
    
Event.prototype.__defineSetter__("returnValue",function(b){// 
        
if(!b)this.preventDefault();
        return 
b;
        });
    
Event.prototype.__defineSetter__("cancelBubble",function(b){// 设置或者检索当前事件句柄的层次冒泡
        
if(b)this.stopPropagation();
        return 
b;
        });
    
Event.prototype.__defineGetter__("srcElement",function(){
        var 
node=this.target;
        while(
node.nodeType!=1)node=node.parentNode;
        return 
node;
        });
    
Event.prototype.__defineGetter__("fromElement",function(){// 返回鼠标移出的源节点
        
var node;
        if(
this.type=="mouseover")
            
node=this.relatedTarget;
        else if(
this.type=="mouseout")
            
node=this.target;
        if(!
node)return;
        while(
node.nodeType!=1)node=node.parentNode;
        return 
node;
        });
    
Event.prototype.__defineGetter__("toElement",function(){// 返回鼠标移入的源节点
        
var node;
        if(
this.type=="mouseout")
            
node=this.relatedTarget;
        else if(
this.type=="mouseover")
            
node=this.target;
        if(!
node)return;
        while(
node.nodeType!=1)node=node.parentNode;
        return 
node;
        });
    
Event.prototype.__defineGetter__("offsetX",function(){
        return 
this.layerX;
        });
    
Event.prototype.__defineGetter__("offsetY",function(){
        return 
this.layerY;
        });
    }
if(
window.Document){// 修正Document的DOM
    /*
                                IE5        MacIE5        Mozilla        Konqueror2.2        Opera5
    document.documentElement    yes        yes            yes            yes                    no
    document.activeElement        yes        null        no            no                    no
    
    */
    
}
if(
window.Node){// 修正Node的DOM
    /*
                                IE5        MacIE5        Mozilla        Konqueror2.2        Opera5
    Node.contains                yes        yes            no            no                    yes
    Node.replaceNode            yes        no            no            no                    no
    Node.removeNode                yes        no            no            no                    no
    Node.children                yes        yes            no            no                    no
    Node.hasChildNodes            yes        yes            yes            yes                    no
    Node.childNodes                yes        yes            yes            yes                    no
    Node.swapNode                yes        no            no            no                    no
    Node.currentStyle            yes        yes            no            no                    no
    
    */
    
Node.prototype.replaceNode=function(Node){// 替换指定节点
        
this.parentNode.replaceChild(Node,this);
        }
    
Node.prototype.removeNode=function(removeChildren){// 删除指定节点
        
if(removeChildren)
            return 
this.parentNode.removeChild(this);
        else{
            var 
range=document.createRange();
            
range.selectNodeContents(this);
            return 
this.parentNode.replaceChild(range.extractContents(),this);
            }
        }
    
Node.prototype.swapNode=function(Node){// 交换节点
        
var nextSibling=this.nextSibling;
        var 
parentNode=this.parentNode;
        
node.parentNode.replaceChild(this,Node);
        
parentNode.insertBefore(node,nextSibling);
        }
    }
if(
window.HTMLElement){
    
HTMLElement.prototype.__defineGetter__("all",function(){
        var 
a=this.getElementsByTagName("*");
        var 
node=this;
        
a.tags=function(sTagName){
            return 
node.getElementsByTagName(sTagName);
            }
        return 
a;
        });
    
HTMLElement.prototype.__defineGetter__("parentElement",function(){
        if(
this.parentNode==this.ownerDocument)return null;
        return 
this.parentNode;
        });
    
HTMLElement.prototype.__defineGetter__("children",function(){
        var 
tmp=[];
        var 
j=0;
        var 
n;
        for(var 
i=0;i<this.childNodes.length;i++){
            
n=this.childNodes[i];
            if(
n.nodeType==1){
                
tmp[j++]=n;
                if(
n.name){
                    if(!
tmp[n.name])
                        
tmp[n.name]=[];
                    
tmp[n.name][tmp[n.name].length]=n;
                    }
                if(
n.id)
                    
tmp[n.id]=n;
                }
            }
        return 
tmp;
        });
    
HTMLElement.prototype.__defineGetter__("currentStyle", function(){
        return 
this.ownerDocument.defaultView.getComputedStyle(this,null);
        });
    
HTMLElement.prototype.__defineSetter__("outerHTML",function(sHTML){
        var 
r=this.ownerDocument.createRange();
        
r.setStartBefore(this);
        var 
df=r.createContextualFragment(sHTML);
        
this.parentNode.replaceChild(df,this);
        return 
sHTML;
        });
    
HTMLElement.prototype.__defineGetter__("outerHTML",function(){
        var 
attr;
        var 
attrs=this.attributes;
        var 
str="<"+this.tagName;
        for(var 
i=0;i<attrs.length;i++){
            
attr=attrs[i];
            if(
attr.specified)
                
str+=" "+attr.name+'="'+attr.value+'"';
            }
        if(!
this.canHaveChildren)
            return 
str+">";
        return 
str+">"+this.innerHTML+"</"+this.tagName+">";
        });
    
HTMLElement.prototype.__defineGetter__("canHaveChildren",function(){
        switch(
this.tagName.toLowerCase()){
            case 
"area":
            case 
"base":
            case 
"basefont":
            case 
"col":
            case 
"frame":
            case 
"hr":
            case 
"img":
            case 
"br":
            case 
"input":
            case 
"isindex":
            case 
"link":
            case 
"meta":
            case 
"param":
                return 
false;
            }
        return 
true;
        });

    
HTMLElement.prototype.__defineSetter__("innerText",function(sText){
        var 
parsedText=document.createTextNode(sText);
        
this.innerHTML=parsedText;
        return 
parsedText;
        });
    
HTMLElement.prototype.__defineGetter__("innerText",function(){
        var 
r=this.ownerDocument.createRange();
        
r.selectNodeContents(this);
        return 
r.toString();
        });
    
HTMLElement.prototype.__defineSetter__("outerText",function(sText){
        var 
parsedText=document.createTextNode(sText);
        
this.outerHTML=parsedText;
        return 
parsedText;
        });
    
HTMLElement.prototype.__defineGetter__("outerText",function(){
        var 
r=this.ownerDocument.createRange();
        
r.selectNodeContents(this);
        return 
r.toString();
        });
    
HTMLElement.prototype.attachEvent=function(sType,fHandler){
        var 
shortTypeName=sType.replace(/on/,"");
        
fHandler._ieEmuEventHandler=function(e){
            
window.event=e;
            return 
fHandler();
            }
        
this.addEventListener(shortTypeName,fHandler._ieEmuEventHandler,false);
        }
    
HTMLElement.prototype.detachEvent=function(sType,fHandler){
        var 
shortTypeName=sType.replace(/on/,"");
        if(
typeof(fHandler._ieEmuEventHandler)=="function")
            
this.removeEventListener(shortTypeName,fHandler._ieEmuEventHandler,false);
        else
            
this.removeEventListener(shortTypeName,fHandler,true);
        }
    
HTMLElement.prototype.contains=function(Node){// 是否包含某节点
        
do if(Node==this)return true;
        while(
Node=Node.parentNode);
        return 
false;
        }
    
HTMLElement.prototype.insertAdjacentElement=function(where,parsedNode){
        switch(
where){
            case 
"beforeBegin":
                
this.parentNode.insertBefore(parsedNode,this);
                break;
            case 
"afterBegin":
                
this.insertBefore(parsedNode,this.firstChild);
                break;
            case 
"beforeEnd":
                
this.appendChild(parsedNode);
                break;
            case 
"afterEnd":
                if(
this.nextSibling)
                    
this.parentNode.insertBefore(parsedNode,this.nextSibling);
                else
                    
this.parentNode.appendChild(parsedNode);
                break;
            }
        }
    
HTMLElement.prototype.insertAdjacentHTML=function(where,htmlStr){
        var 
r=this.ownerDocument.createRange();
        
r.setStartBefore(this);
        var 
parsedHTML=r.createContextualFragment(htmlStr);
        
this.insertAdjacentElement(where,parsedHTML);
        }
    
HTMLElement.prototype.insertAdjacentText=function(where,txtStr){
        var 
parsedText=document.createTextNode(txtStr);
        
this.insertAdjacentElement(where,parsedText);
        }
    
HTMLElement.prototype.attachEvent=function(sType,fHandler){
        var 
shortTypeName=sType.replace(/on/,"");
        
fHandler._ieEmuEventHandler=function(e){
            
window.event=e;
            return 
fHandler();
            }
        
this.addEventListener(shortTypeName,fHandler._ieEmuEventHandler,false);
        }
    
HTMLElement.prototype.detachEvent=function(sType,fHandler){
        var 
shortTypeName=sType.replace(/on/,"");
        if(
typeof(fHandler._ieEmuEventHandler)=="function")
            
this.removeEventListener(shortTypeName,fHandler._ieEmuEventHandler,false);
        else
            
this.removeEventListener(shortTypeName,fHandler,true);
        }
    }
//-->
</script>
?>




学会用下半身来思考!
2005-4-28 04:47 AM#2
查看资料  Blog  发短消息  QQ  顶部
     


  可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题 | 开通个人空间  


 


Powered by Discuz! 6.1.0  © 2001-2010 Comsenz Inc.
Processed in 0.072076 second(s), 6 queries

(冀ICP备05009913号) 管理员:sadly 邮箱/MSN: sadly@phpx.com QQ:824008(长隐) 清除 Cookies - - Archiver - WAP