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(....), 例如:
(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.textC;}
}
</script>
<font id="aa">0000</font><input type="button" >