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

javascript 動(dòng)態(tài)添加事件代碼

 更新時(shí)間:2008年11月30日 16:51:56   作者:  
往往我們需要在 JS 中動(dòng)態(tài)添加事件,這就涉及到瀏覽器兼容性問題了,以下談及的幾種方法,我們也常?;旌鲜褂谩?/div>
方法一、setAttribute
var obj = document.getElementById("obj");
obj.setAttribute("onclick", "javascript:alert('測(cè)試');");
這里利用 setAttribute 指定 onclick 屬性,簡(jiǎn)單,很好理解,
但是:IE 不支持,IE 并不是不支持 setAttribute 這個(gè)函數(shù),而是不支持用 setAttribute 設(shè)置某些屬性,包括對(duì)象屬性、集合屬性、事件屬性,也就是說用 setAttribute 設(shè)置 style、onclick、onmouseover 這些屬性在 IE 中是行不通的。
方法二、用 attachEvent 和 addEventListener
IE 支持 attachEvent
obj.attachEvent("onclick", Foo);
function Foo()
{
alert("測(cè)試");
}
也可寫在一起
obj.attachEvent("onclick", function(){alert("測(cè)試");});
其它瀏覽器支持 addEventListener
obj.addEventListener("click", Foo, false);
function Foo()
{
alert("測(cè)試");
}
同樣也可寫在一起
obj.addEventListener("click", function(){alert("測(cè)試");}, false);
注意 attachEvent 的事件帶 on,如 onclick,而 addEventListener 不帶 on,如 click。
順便說一下 addEventListener 的第三個(gè)參數(shù)(雖然很少用) useCapture - 如果為 true,則 useCapture 指示用戶希望啟動(dòng)捕獲。啟動(dòng)捕獲后,所有指定類型的事件將在被指派到樹中其下面的任何 EventTargets 之前指派給已注冊(cè)的 EventListener。正在通過樹向上 bubbling 的事件將不觸發(fā)指定的使用捕獲的 EventListener。
綜合應(yīng)用
if (window.attachEvent)
{
//IE 的事件代碼
}
else
{
//其它瀏覽器的事件代碼
}
方法三、事件 = 函數(shù)
例:obj.onclick = Foo;
這在多個(gè)瀏覽器中均支持,這是屬于舊的規(guī)范(方法二屬于 DOM2 的規(guī)范),不過由于使用方便,用的場(chǎng)合也比較多。

下面是我的解決辦法:
function show(){
alert("Hello, world!!!");
}
obj.setAttribute('onclick',document.all ? eval(function(){show()}) : 'javascript:show()');
看起來很簡(jiǎn)單,也兼容瀏覽器,就是不知道還有沒有其他方面的影響,或者有更好的方法可以取代呢?

相關(guān)文章

  • Promise中的then鏈機(jī)制用法詳解

    Promise中的then鏈機(jī)制用法詳解

    這篇文章給大家詳細(xì)介紹了Promise中的then鏈機(jī)制用法,每一次 .then都會(huì)返回一個(gè)新的promise實(shí)例,文中通過代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • 淺談webpack對(duì)樣式的處理

    淺談webpack對(duì)樣式的處理

    這篇文章主要介紹了淺談webpack對(duì)樣式的處理,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • 網(wǎng)頁中右鍵功能的實(shí)現(xiàn)方法之contextMenu的使用

    網(wǎng)頁中右鍵功能的實(shí)現(xiàn)方法之contextMenu的使用

    本文介紹一種網(wǎng)頁中實(shí)現(xiàn)右鍵功能的方案–contextMenu,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-02-02
  • 寫了10年的Javascript也未必全了解的連續(xù)賦值運(yùn)算

    寫了10年的Javascript也未必全了解的連續(xù)賦值運(yùn)算

    很喜歡 蔡蔡 的這個(gè)標(biāo)題,實(shí)際蔡蔡已經(jīng)分析過了,這里借用了?;蛟S有點(diǎn)標(biāo)題黨的意思??赐昃椭?。
    2011-03-03
  • 小程序接入騰訊位置服務(wù)的詳細(xì)流程

    小程序接入騰訊位置服務(wù)的詳細(xì)流程

    這篇文章主要介紹了小程序接入騰訊位置服務(wù)的詳細(xì)流程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • 用JavaScript仿PS里的羽化效果代碼

    用JavaScript仿PS里的羽化效果代碼

    JavaScript圓形虛幻效果,跟PS里面的羽化效果有點(diǎn)像,需要的朋友可以參考下。
    2011-12-12
  • webpack打包html里面img后src為“[object Module]”問題

    webpack打包html里面img后src為“[object Module]”問題

    這篇文章主要介紹了webpack打包html里面img后src為“[object Module]”問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • JS定時(shí)器實(shí)現(xiàn)數(shù)值從0到10來回變化

    JS定時(shí)器實(shí)現(xiàn)數(shù)值從0到10來回變化

    最近做項(xiàng)目遇到一需求要求實(shí)現(xiàn)數(shù)值從0到10來回變化,下面小編給大家分享下實(shí)現(xiàn)代碼,需要的朋友參考下
    2016-12-12
  • 一文詳解MySQL5.7與MySQL8之間的區(qū)別

    一文詳解MySQL5.7與MySQL8之間的區(qū)別

    MySQL作為最常用的開源關(guān)系型數(shù)據(jù)庫管理系統(tǒng)之一,一直在不斷發(fā)展和改進(jìn),其中,MySQL 5.7和MySQL 8是兩個(gè)備受關(guān)注的版本,它們之間存在一些關(guān)鍵的差異,本文將深入探討這兩個(gè)版本之間的主要差異,需要的朋友可以參考下
    2023-11-11
  • JavaScript forEach 方法跳出循環(huán)的操作方法

    JavaScript forEach 方法跳出循環(huán)的操作方法

    這篇文章主要介紹了JavaScript forEach 方法跳出循環(huán)的操作方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-01-01

最新評(píng)論