现在的位置: 首页 > 综合 > 正文

IE6,IE7和FireFox兼容处理

2018年02月01日 ⁄ 综合 ⁄ 共 2355字 ⁄ 字号 评论关闭
 

1. event.srcElement 属性:
IE下可以使用event.srcElement属性,但在Firefox下只有target属性,所以要兼容两者需使用:
var el = evt.srcElement ? evt.srcElement : evt.target;

2. document.all 属性:
在IE下可以引用document.all属性获取所有dom内容,但在firefox下只能使用
document.getElementsByTagName("*")

3."event is not defined" FireFox event 問題處理:

FireFox 與 IE 在event方面的不同是在於FireFox 是遵照W3C的規格, 換言之是沒有event 這個內建物件,所以會出現的錯誤訊息是"event is not defined",而IE 是把event會丟給window.event,
因此同樣的Javascript 在firefox上是會出現問題的,這裡提出一個通用的辦法.
 
(1) 在定義function name時請多加一個參數叫event or evt, 不管你的function 有沒有其他參數要傳, 習慣上放在第一個位置,至於它的值就不需理它,如下:
   funname( event,....)  {
 
   var evt = event ? event : (window.event ? window.event : null);
   
    if (document.all) // IE
    {
        var x =   event.x ;                   // 取得滑鼠指標目前的 x 位置
        var y =   event.y ;                   // 取得滑鼠指標目前的 y 位置
    }
    else  // firefox
    {
        var x = evt.clientX;  // 取得滑鼠指標目前的 x 位置
         var y = evt.clientY;  // 取得滑鼠指標目前的 y 位置
       
    }
  
     ...
   }
   紅色的Event那行是很重要的,也不一定宣告成event, evt 都可以
 
(2)再呼叫此javascript function 時請在之前加上javascript: funname(....), 例如:
      onmouseover="javascript: funname(event, ....); "
 
(3)如此便可正常呼叫了,另外IE與Firefox 有些物件的呼叫方式不同,例如:
 
       IE 的 event.srcElement <==>  Firefox中的 event.target
       IE 的 a.innerText  <==>  Firefox中的 a.textContent
       IE 的 document.all[obj].style <==>  Firefox中的 document.getElementById(obj).style

4. IE6和IE7在display:block的区别
IE6 对 A标签 的 display:block 解释有误,会对block属性失效,具体的解决办法是将a标签加上一个固定的高度,如下:
* {
 margin:0px;
 padding:0px;
 border:none;
}
ul {
 width:100px;
 font: 12px Verdana;
}
li{
 width:100%;
 height:20px;
 background-color:#CCCCCC;
 margin:2px 10px;
}
li a{
 display:block;
 width:100%;//加上这两句
 height:100%;//加上这两句
 text-decoration:none;
}
li a:hover{
 background-color:#999999;
}
-->
</style>
</head>
<body>
<ul>
<li><a href="#">aaaaaa</a></li>
<li><a href="#">bbbbbb</a></li>
<li><a href="#">cccccc</a></li>
<li><a href="#">dddddd</a></li>
<li><a href="#">eeeeee</a></li>
<li><a href="#">ffffff</a></li>
</ul>
</body>
</html>

5. InnerText的区别:Firefox不支持InnerText需要用textContent代替:
<script language="javascript">
function faa(){
if(document.all){aa.innerText="11111"}else{aa.textContent="11111";}
}
</script>
<font id="aa">0000</font><input type="button" onclick="faa()">

 

6.event.keyCode 和event.which

FF不支持window.event.keyCode,代替着是event.which

列子:

//在网页上面屏蔽tab键的代码
document.onkeydown = function (e){
            var theEvent = window.event || e;
            var code = theEvent.keyCode || theEvent.which;
            if(code == 9){
              return false;
            }
}

 

firefox取消事件的的方法

e.cancelBubble = true;

return false;

即可。

抱歉!评论已关闭.