四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

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 動態添加事件代碼,轉載需保留來源!

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

主站蜘蛛池模板: 韩国xxxxxxxxxxxx| 诺斯费拉图2024| 男女打扑克视频网站| 成龙电影免费看40部| 国生小百合| 老字号传奇 电视剧| 追捕电影完整版免费| 安吉拉·莫雷纳| 恋爱三万英尺| 在线看色戒| 延边卫视节目表今天| 高地1—36集电视剧免费观看剧情| 哦,苏珊娜| 王尧演员| 妈妈的朋友欧美| 《杨贵妃淫史》三级| 甜姐儿| intel集成显卡天梯图| 徐蔓华| 林海雪原演员表| 泰迪熊 美剧| 孕妇能吃杏仁吗| 老江湖| 山上的小屋 残雪原文| 陈若| 追踪 电影| 康熙王朝50集免费观看投屏电视剧| 温暖的抱抱 电影| 极品电影网| 帕罗| 六一儿童节对联七字| 极寒复出| 美女写真裸体| 笔仙2大尺度床戏| 比基尼美女跳舞视频| 香港之夜免费播放国语| 电影《真爱》完整播放| 宫心计演员表介绍| 城市风云儿| 市川美织| ktv视频|