js
看例子:
運行代碼框
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>Untitled Document</title></head><body><li><a href="http://www.blueidea.com/articleimg/bbsimg/smile.gif"/></a><a href="圖片地址">開啟</a></li><li><a href="/UploadPic/2007-7/200777165141224.gif"/></a><a href="圖片地址">開啟</a></li><li><a href="/UploadPic/2007-7/200777165141253.gif"/></a><a href="圖片地址">開啟</a></li></body></html><script language="javascript" type="text/javascript">document.body.onclick = function(evt){ evt = evt || window.event; var o = evt.target || evt.srcElement; window.open(o.previousSibling.href || o.previousSibling.previousSibling.href); return false;}</script>
[Ctrl+A 全部選擇 提示:你可先修改部分代碼,再按運行]
找到 document.body.onclick = function(evt),
在IE下,這個evt是不會有的,但是在fireFox下(opera下好像也是)會預設傳這個參數.在IE下,這個參數是 null ,想相容,就這樣寫.
繼續向下:
evt = evt || window.event;
在IE下,evt 就會指向:window.event,在fireFox下,就會指向那個預設參數.
因為在IE下 evt || window.event 相當於: null || window.event,結果還是window.event
而在fireFox下,就相當於 evt || null ,結果就是evt
向下看:
o.previousSibling.href || o.previousSibling.previousSibling.href
前面一個運算式用於IE下,後面一個用於FireFox下.
因為在IE下,XMLDom沒有preserveWhiteSpace這個屬性,即:把空白也當作一個節點,而IE則預設為false,即把空白不看成一個節點.
這裡說到了XMLDom,似乎和上面所說的不相關,但是在FireFox下 previousSibling就是空白,除非兩個HTML標籤之間沒有任何形式的空格.
<a href="http://www.blueidea.com/articleimg/bbsimg/smile.gif"/></a>
<a href="圖片地址">開啟</a>
兩個<a>之間有換行(屬於空格的一種),所以在FireFox下,取下面一個<a>的前一個節點的話,就必須用:
o.previousSibling.previousSibling.href
可能你還是沒有看明白,沒關係,再舉個簡單的:
運行代碼框
<script>function test(p1,p2,p3){ p1 = p1 || 100; p2 = p2 || "xlingFairy"; return "p1 = " + p1 + " p2 = " + p2 + " p3 = " + p3;}alert(test());alert(test(null,null,"blueidea.com"))</script>
[Ctrl+A 全部選擇 提示:你可先修改部分代碼,再按運行]
好,點道為止,就講這些!