亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2008年01月12日 15:08:43   作者:  
解讀IE和firefox下JScript和HREF的執(zhí)行順序

很久都沒(méi)有寫(xiě)關(guān)于代碼方面的文章了。主要原因還是因?yàn)樽罱墓ぷ鞫技性谛枨蠓治龇矫妫瑳](méi)有了現(xiàn)實(shí)中的感觸,就沒(méi)有了寫(xiě)作的動(dòng)機(jī)。討論一個(gè)關(guān)于JScript執(zhí)行順序的問(wèn)題。示例代碼如下:
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)有個(gè)注釋掉的行,試驗(yàn)的時(shí)候分別執(zhí)行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 

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

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

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

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

相關(guān)文章

  • js a標(biāo)簽點(diǎn)擊事件

    js a標(biāo)簽點(diǎn)擊事件

    本文將詳細(xì)介紹a標(biāo)簽上的點(diǎn)擊事件的相關(guān)知識(shí)。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-03-03
  • JavaScript 檢測(cè)文件的類(lèi)型的方法

    JavaScript 檢測(cè)文件的類(lèi)型的方法

    在日常工作中,文件上傳是一個(gè)很常見(jiàn)的功能。在某些情況下,我們希望能限制文件上傳的類(lèi)型,比如限制只能上傳 PNG 格式的圖片。本文就將針對(duì)這個(gè)問(wèn)題,來(lái)講解如何檢測(cè)文件的類(lèi)型
    2021-05-05
  • JS 組件系列之BootstrapTable的treegrid功能

    JS 組件系列之BootstrapTable的treegrid功能

    這篇文章主要介紹了JS 組件系列之BootstrapTable的treegrid功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-06-06
  • JS實(shí)現(xiàn)電商商品展示放大鏡特效

    JS實(shí)現(xiàn)電商商品展示放大鏡特效

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)電商商品展示放大鏡特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • web前端頁(yè)面生成exe可執(zhí)行文件的方法

    web前端頁(yè)面生成exe可執(zhí)行文件的方法

    這篇文章給大家介紹了Electron 怎么將網(wǎng)頁(yè)打包成桌面應(yīng)用(web前端頁(yè)面怎么生成exe可執(zhí)行文件),感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-02-02
  • echarts餅圖labelLine線(xiàn)的長(zhǎng)度自適應(yīng)設(shè)置

    echarts餅圖labelLine線(xiàn)的長(zhǎng)度自適應(yīng)設(shè)置

    這篇文章主要給大家介紹了關(guān)于echarts餅圖labelLine線(xiàn)的長(zhǎng)度自適應(yīng)設(shè)置的相關(guān)資料,在echarts中,餅圖的標(biāo)簽線(xiàn)可以通過(guò)設(shè)置 labelLine屬性來(lái)自定義位置,需要的朋友可以參考下
    2023-08-08
  • CSS+Js遮罩效果的TAB及焦點(diǎn)圖片切換(推薦)

    CSS+Js遮罩效果的TAB及焦點(diǎn)圖片切換(推薦)

    CSS+Js圖片切換技術(shù),類(lèi)似的已有不少了,這一個(gè)使用了遮罩過(guò)渡的效果,同樣應(yīng)用到了TAB選項(xiàng)卡上,本頁(yè)面僅是為了演示,大家用時(shí)候把它拆分開(kāi)來(lái),這個(gè)效果也對(duì)學(xué)習(xí)圖片效果制作很有幫助。
    2009-11-11
  • 細(xì)說(shuō)JavaScript中的變量,作用域和垃圾回收

    細(xì)說(shuō)JavaScript中的變量,作用域和垃圾回收

    這篇文章主要和大家介紹一下JavaScript中的變量,作用域和垃圾回收的定義與使用,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)JavaScript有一定的幫助,需要的可以參考一下
    2022-11-11
  • 關(guān)于uniapp的request封裝保姆級(jí)教程

    關(guān)于uniapp的request封裝保姆級(jí)教程

    這篇文章主要給大家介紹了關(guān)于uniapp的request封裝保姆級(jí)教程,request是基于uni-app框架封裝的一個(gè)網(wǎng)絡(luò)請(qǐng)求庫(kù),可以用于發(fā)送http請(qǐng)求和處理響應(yīng)數(shù)據(jù),需要的朋友可以參考下
    2023-07-07
  • 用js怎么把&字符換成"&amp:"

    用js怎么把&字符換成"&amp:"

    用js怎么把&字符換成"&amp:"...
    2006-10-10

最新評(píng)論