欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入理解在JS中通過四種設(shè)置事件處理程序的方法

 更新時(shí)間:2017年03月02日 09:38:47   作者:菜鳥葫蘆娃  
所有的JavaScript事件處理程序的作用域是在其定義時(shí)的作用域而非調(diào)用時(shí)的作用域中執(zhí)行,并且它們能存取那個(gè)作用域中的任何一個(gè)本地變量。但是HTML標(biāo)簽屬性注冊處理程序就是一個(gè)例外。看下面四種方式

所有的JavaScript事件處理程序的作用域是在其定義時(shí)的作用域而非調(diào)用時(shí)的作用域中執(zhí)行,并且它們能存取那個(gè)作用域中的任何一個(gè)本地變量。但是HTML標(biāo)簽屬性注冊處理程序就是一個(gè)例外??聪旅嫠姆N方式:

第一種方式(HTML標(biāo)簽屬性):

<input type="button" id="btn1" value="測試" onclick="alert(this.id);" />

上面的代碼是通過設(shè)置HTML標(biāo)簽屬性為給button 添加了點(diǎn)擊事件,當(dāng)點(diǎn)擊button 按鈕時(shí)會彈出這個(gè)button的id,即btn1。

這種通過HTML屬性來注冊事件處理程序是一個(gè)例外。它們被轉(zhuǎn)換為能存取全局變量的頂級函數(shù)而非任何本地變量。由于歷史的原因,它們運(yùn)行在一個(gè)修改后的作用域鏈中。通過HTML屬性定義的事件處理程序能像本地變量一樣使用目標(biāo)對象、容器對象(form)對象和document對象的屬性。它會被瀏覽器轉(zhuǎn)換為類似如下的代碼:

 function (event){
  with(document){
   with(this.form||{}){
    with(this){
     /*具體的事件處理代碼*/
    }
   }
  }  
}

關(guān)于with的用法,可以自行查閱,這里后面有文章講解。讀者先自行了解一下。提供一個(gè)連接(https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Statements/with

這種方式現(xiàn)在已經(jīng)不推薦使用。

第二種方式(調(diào)用函數(shù))

<input type="button" id="btn2" value="測試" onclick="test()" />
<script type="text/javascript">
  function test(){
   alert(this.id);
  }
</script>

這段代碼彈出來的是undefined。

這種設(shè)置方式是通過調(diào)用全局函數(shù)來進(jìn)行的,這時(shí)this指向的是window,而非這個(gè)button的調(diào)用者,可以通過輸出console.log(this==window);來進(jìn)行驗(yàn)證

第三種方式(調(diào)用函數(shù))

<input type="button" id="btn3" value="測試" />
<script type="text/javascript">
   var btn3 = document.getElementById("btn3");
        btn3.onclick = function () {
          alert(this.id);
        };
</script>

這段代碼彈出來的是btn3。

這種事件處理程序在事件目標(biāo)上定義,所以它們作為這個(gè)對象的方法來調(diào)用(但是下面在IE里面有個(gè)例外)。這就是說在事件處理程序內(nèi),this關(guān)鍵字指的是事件目標(biāo)。

當(dāng)使用addEventListener()注冊時(shí),調(diào)用的處理程序使用事件目標(biāo)作為它們的this值。但是對于還用attachment()注冊的處理程序作為函數(shù)調(diào)用,它們的this值是全局(window)對象。就是說的第四中方式

第四種方式(通過addEventListener和attachment):

<input type="button" id="btn3" value="測試" onclick="test()" />
 var btn = document.getElementById("btn3");
        var handler = function () { console.log(this.id); };
        if (btn.addEventListener) {
          console.log("addEventListener");
          btn.addEventListener("click", handler, false);
        }
        else if (btn.attachEvent) {//IE9之前的版本
          console.log("attachEvent");
          btn.attachEvent("onclick",handler);
        }

在IE5-IE8 版本輸出的是undefined。(此時(shí)調(diào)用的是attachement)

IE9以后的版本輸出的btn3.(修復(fù)了上面的問題,增加了通用的addEventListener)。

如果想修復(fù)IE5-8里面的那個(gè)問題,可以使用下面的方法。

/*
*target:目標(biāo)對象,button之類的
*type:"click"字符串事件名稱,無需帶on
*handler:調(diào)用的處理程序
*/
function addEvent(target,type,handler){
 if (target.addEventListener) {
          target.addEventListener(type, handler, false);
        }
        else if (target.attachEvent) {//IE9之前的版本          
          btn.attachEvent("on"+type,function(event){
            return hanlder.call(target,event);//把處理程序作為事件目標(biāo)的方法調(diào)用,更改this指向。
          });
        }
}

以上所述是小編給大家介紹的在JS中通過四種設(shè)置事件處理程序的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • JavaScript腳本性能優(yōu)化注意事項(xiàng)

    JavaScript腳本性能優(yōu)化注意事項(xiàng)

    本文總結(jié)了我在JavaScript編程中所找到的提高JavaScript運(yùn)行性能的一些方法,其實(shí)這些經(jīng)驗(yàn)都基于幾條原則
    2008-11-11
  • 使用正則替換變量

    使用正則替換變量

    使用正則替換變量...
    2007-05-05
  • JavaScript可視化與Echarts詳細(xì)介紹

    JavaScript可視化與Echarts詳細(xì)介紹

    提到數(shù)據(jù)可視化相信大家都不陌生,它能夠?qū)我坏臄?shù)據(jù)通過合適的可視化圖表類型表現(xiàn)出來,使其更加直觀的展現(xiàn)數(shù)據(jù)的變化趨勢、對比、峰值等等。其實(shí)在前端開發(fā)中,數(shù)據(jù)可視化也尤為重要,在眾多圖表庫中,echarts就是最常見的圖表庫之一
    2022-07-07
  • 原生js實(shí)現(xiàn)each方法實(shí)例代碼詳解

    原生js實(shí)現(xiàn)each方法實(shí)例代碼詳解

    這篇文章主要介紹了原生js實(shí)現(xiàn)each方法,需要的朋友可以參考下
    2019-05-05
  • Bootstrap學(xué)習(xí)筆記 輪播(Carousel)插件

    Bootstrap學(xué)習(xí)筆記 輪播(Carousel)插件

    Bootstrap 輪播(Carousel)插件是一種靈活的響應(yīng)式的向站點(diǎn)添加滑塊的方式。這篇文章主要介紹了Bootstrap學(xué)習(xí)筆記 輪播(Carousel)插件,需要的朋友可以參考下
    2017-03-03
  • JS中JSON對象和String之間的互轉(zhuǎn)及處理技巧

    JS中JSON對象和String之間的互轉(zhuǎn)及處理技巧

    JSON:JavaScript 對象表示法(JavaScript Object Notation),其實(shí)JSON就是一個(gè)JavaScript的對象(Object)而已。接下來通過本文給大家介紹JS中JSON對象和String之間的互轉(zhuǎn)及處理技巧,需要的朋友一起學(xué)習(xí)吧
    2016-04-04
  • 微信小程序?qū)崿F(xiàn)簡單計(jì)算器功能

    微信小程序?qū)崿F(xiàn)簡單計(jì)算器功能

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)簡單計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • 優(yōu)化javascript的執(zhí)行效率一些方法總結(jié)

    優(yōu)化javascript的執(zhí)行效率一些方法總結(jié)

    本文為大家介紹下優(yōu)化javascript的執(zhí)行效率一些方法,個(gè)人感覺還不錯(cuò),感興趣的朋友可以了解下
    2013-12-12
  • JavaScript 有用的代碼片段和 trick

    JavaScript 有用的代碼片段和 trick

    這篇文章主要介紹了JavaScript 有用的代碼片段和 trick的相關(guān)知識,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • JS中常用的消息框總結(jié)

    JS中常用的消息框總結(jié)

    小編給大家總結(jié)了JS最常用到的幾種消息提示框,大家應(yīng)該經(jīng)常用的到,一起學(xué)習(xí)下吧。
    2018-02-02

最新評論