|
很久都沒有寫關于代碼方面的文章了。主要原因還是因為最近的工作都集中在需求分析方面,沒有了現實中的感觸,就沒有了寫作的動機。討論一個關于JScript執行順序的問題。示例代碼如下:
a.htm
<A onmouseup="func('onmouseup')" href="b.htm">Click Me!</A> <A onclick="func2('onclick')" href="d.htm">Click Me!</A> <SPAN id=msg></SPAN>
<SCRIPT>
function func(str)
{
msg(str);
window.location.href="c.htm";
}
function msg(str)
{
document.getElementById("msg").innerText=str; //A
//alert(str); //B
}
function func2(str)
{
msg(str);
window.location.href="e.htm";
}
</SCRIPT>
在msg(str)有個注釋掉的行,試驗的時候分別執行A和B。
A | B | |||
onmouseup | onclick | onmouseup | onclick | |
IE | b.htm | d.htm | c.htm | d.htm |
FireFox | c.htm->b.htm | e.htm->d.htm | c.htm->b.htm | e.htm->d.htm |
上表主要列出了兩個瀏覽器中的執行順序,紅色代表頁面腳本跳轉的頁面,藍色是Anchor標簽的href屬性。從上面可以看出,對于FireFox,始終先執行頁面腳本,然后瀏覽器再跳轉。而IE里面執行的過程卻有差別:
1、使用后退按鈕直接回到a.htm,即頁面只執行了一個跳轉;
2、在使用alert中斷的情況下,onmouseup執行了頁面腳本中的跳轉。
從上可以看出,
1、對于FireFox而言,頁面腳本執行順序始終優先于瀏覽器內嵌腳本執行順序,這個已經很明顯了。
2、IE中,HREF的執行順序為onmouseup->href->onclick。真的嗎?
為了更加明確2中的執行順序,我們繼續分析onclick和href的執行順序關系。在上述例子中,onclick是采用調入的方式執行的。如果a. 我們使用以下的測試代碼:
<a href="d.htm" onclick="return false;">Click Me!</a>
發現HREF不能被執行。
b. 如果我們使用以下測試代碼:
<a href="d.htm" onclick="window.location.href='e.htm';return false;">Click Me!</a>
發現依舊執行HREF的d.htm,而不是onclick中的e.htm。
c. 如果我們使用以下測試代碼:
<a href="d.htm" onclick="msg('onclick');return false;">Click Me!</a>( function msg()的代碼如上)
發現執行了function msg(),而HREF不被觸發。
暈了。IE的確是個詭異的東西。誰能幫忙解釋一下b例中的現象?
JavaScript技術:解讀IE和firefox下JScript和HREF的執行順序,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。