色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

解讀IE和firefox下JScript和HREF的執(zhí)行順序

很久都沒有寫關于代碼方面的文章了。主要原因還是因為最近的工作都集中在需求分析方面,沒有了現(xiàn)實中的感觸,就沒有了寫作的動機。討論一個關于JScript執(zhí)行順序的問題。示例代碼如下:
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)有個注釋掉的行,試驗的時候分別執(zhí)行A和B。

  A B
 onmouseup onclick onmouseuponclick 
 IE b.htm d.htm c.htmd.htm 
 FireFox c.htm->b.htm e.htm->d.htm c.htm->b.htme.htm->d.htm 

上表主要列出了兩個瀏覽器中的執(zhí)行順序,紅色代表頁面腳本跳轉的頁面,藍色是Anchor標簽的href屬性。從上面可以看出,對于FireFox,始終先執(zhí)行頁面腳本,然后瀏覽器再跳轉。而IE里面執(zhí)行的過程卻有差別:
1、使用后退按鈕直接回到a.htm,即頁面只執(zhí)行了一個跳轉;
2、在使用alert中斷的情況下,onmouseup執(zhí)行了頁面腳本中的跳轉。

從上可以看出,
1、對于FireFox而言,頁面腳本執(zhí)行順序始終優(yōu)先于瀏覽器內嵌腳本執(zhí)行順序,這個已經很明顯了。
2、IE中,HREF的執(zhí)行順序為onmouseup->href->onclick。真的嗎?

為了更加明確2中的執(zhí)行順序,我們繼續(xù)分析onclick和href的執(zhí)行順序關系。在上述例子中,onclick是采用調入的方式執(zhí)行的。如果a. 我們使用以下的測試代碼:
<a href="d.htm" onclick="return false;">Click Me!</a>
發(fā)現(xiàn)HREF不能被執(zhí)行。
b. 如果我們使用以下測試代碼:
<a href="d.htm" onclick="window.location.href='e.htm';return false;">Click Me!</a>
發(fā)現(xiàn)依舊執(zhí)行HREF的d.htm,而不是onclick中的e.htm。
c. 如果我們使用以下測試代碼:
<a href="d.htm" onclick="msg('onclick');return false;">Click Me!</a>( function msg()的代碼如上)
發(fā)現(xiàn)執(zhí)行了function msg(),而HREF不被觸發(fā)。

暈了。IE的確是個詭異的東西。誰能幫忙解釋一下b例中的現(xiàn)象?

JavaScript技術解讀IE和firefox下JScript和HREF的執(zhí)行順序,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 乐清市| 东兴市| 青田县| 台州市| 嘉祥县| 原平市| 邵阳县| 淳化县| 浦城县| 永修县| 尤溪县| 罗田县| 博兴县| 广德县| 中江县| 肥东县| 会泽县| 滨海县| 水城县| 桐乡市| 揭东县| 噶尔县| 公安县| 嘉荫县| 石林| 姜堰市| 桓仁| 建德市| 寻甸| 邵阳市| 长武县| 鄂州市| 田阳县| 海南省| 云梦县| 盘锦市| 汝城县| 西丰县| 中阳县| 翁源县| 红原县|