[JS]用空格或 || 來相容FireFox

來源:互聯網
上載者:User
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 全部選擇 提示:你可先修改部分代碼,再按運行]

好,點道為止,就講這些!



相關文章

Beyond APAC's No.1 Cloud

19.6% IaaS Market Share in Asia Pacific - Gartner IT Service report, 2018

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。