一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

javascript 動態添加事件代碼

方法一、setAttribute
var obj = document.getElementById("obj");
obj.setAttribute("onclick", "Javascript:alert('測試');");
這里利用 setAttribute 指定 onclick 屬性,簡單,很好理解,
但是:IE 不支持,IE 并不是不支持 setAttribute 這個函數,而是不支持用 setAttribute 設置某些屬性,包括對象屬性、集合屬性、事件屬性,也就是說用 setAttribute 設置 style、onclick、onmouseover 這些屬性在 IE 中是行不通的。
方法二、用 attachEvent 和 addEventListener
IE 支持 attachEvent
obj.attachEvent("onclick", Foo);
function Foo()
{
alert("測試");
}
也可寫在一起
obj.attachEvent("onclick", function(){alert("測試");});
其它瀏覽器支持 addEventListener
obj.addEventListener("click", Foo, false);
function Foo()
{
alert("測試");
}
同樣也可寫在一起
obj.addEventListener("click", function(){alert("測試");}, false);
注意 attachEvent 的事件帶 on,如 onclick,而 addEventListener 不帶 on,如 click。
順便說一下 addEventListener 的第三個參數(雖然很少用) useCapture - 如果為 true,則 useCapture 指示用戶希望啟動捕獲。啟動捕獲后,所有指定類型的事件將在被指派到樹中其下面的任何 EventTargets 之前指派給已注冊的 EventListener。正在通過樹向上 bubbling 的事件將不觸發指定的使用捕獲的 EventListener。
綜合應用
if (window.attachEvent)
{
//IE 的事件代碼
}
else
{
//其它瀏覽器的事件代碼
}
方法三、事件 = 函數
例:obj.onclick = Foo;
這在多個瀏覽器中均支持,這是屬于舊的規范(方法二屬于 DOM2 的規范),不過由于使用方便,用的場合也比較多。

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

JavaScript技術javascript 動態添加事件代碼,轉載需保留來源!

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

主站蜘蛛池模板: 好色123| 激情小视频在线播放免费 | 日韩专区中文字幕 | 韩国欧洲一级毛片免费 | 美女黄网站 | 国产精品 视频一区 二区三区 | 日本一本在线视频 | 国产日韩欧美一区二区三区视频 | 黄色小视频在线免费观看 | 久久久久久久久女黄9999 | 国产资源在线看 | 网站色哟哟 | 香蕉视频成人在线观看 | 亚洲欧美日韩视频一区 | 激情五月开心婷婷 | 女人被狂躁的免费视频网站软件 | 五月天六月婷婷 | 手机在线一区二区三区 | 在线黄色观看 | 亚洲六月丁香六月婷婷花 | 中文字幕一区二区三区有限公司 | 青青视频国产在线播放 | 美女网站视频黄色 | 中国美女一级毛片 | 在线国产资源 | 精品国产一区二区三区麻豆小说 | 国产区图片区小说区亚洲区 | 巨大巨粗巨长的黑吊免费视频 | 亚洲狠狠97婷婷综合久久久久 | 久久亚洲影院 | 激情一区二区三区成人 | www.亚洲一区 | 色老板在线永久免费视频凹凸 | 久草资源在线 | 韩国美女一级片 | 亚洲精品美女久久久aaa | 国产精品亚洲国产三区 | 精品精品久久宅男的天堂 | 国产成人精品亚洲午夜麻豆 | 日本一区二区在线不卡 | 黄色在线视频在线观看 |