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

JavaScript 事件屬性綁定帶參數的函數

例如不能采用這種調用方式:element.onclick = test();element.onclick = test(arg1,arg2);只能通過element.onclick = function(){ ... };或者element.onclick = test這種方式來實現,所以無法給函數傳遞參數。參考了大量的網上資料,解決這個問題的方式,以代碼為例,如下所示:
復制代碼 代碼如下:
function Handler() { };
Handler.prototype = {
/*
* 把eventType類型的事件綁定到element元素,并使用handler事件句柄進行處理
* 兼容 IE 及 Firefox 等瀏覽器
*
* @param element 在其上注冊事件的對象(Object)
* @param eventType 注冊的事件類型(String),不加“on”
* @param handler 事件句柄(Function)
*/
registerEvent : function(element, eventType, handler) {
if(element.attachEvent) { //2級DOM的事件處理
element.attachEvent('on'+ eventType, handler);
}else if (element.addEventListener) {
element.addEventListener(eventType, handler, false);
} else { //0級DOM的事件處理
element['on'+ eventType] = handler;
}
},
/*
* 獲得帶參數的事件句柄的引用
*
* @param obj 需要綁定事件處理函數的所有者,null 表示 window 對象
* @param func 需要綁定的事件處理函數名
* @param ... 第三個參數開始為綁定事件處理函數的參數,由 0 到多個構成
*/
bind: function(obj, handler) {
obj = obj || window;
var args = [];
for(var i =2; i < arguments.length; i++)
{
args.push(arguments[i]);
}
return function() { handler.apply(obj, args) };
}
}
可能是使用方式為:
function show(txtObj) {
alert(txtObj.value);
txtObj.focus();
txtObj.select();
}
window.onload = function(){
var handler = new Handler();
handler.registerEvent($("txt"), "change", handler.bind(null,show,$("txt")));//采用2級事件模型的方式
//$("txt").onchange = handler.bind(null,show,$("txt"));//JavaScript事件屬性的方式
}

JavaScript技術JavaScript 事件屬性綁定帶參數的函數,轉載需保留來源!

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

主站蜘蛛池模板: 国产在线综合一区二区三区 | 国产小视频在线高清播放 | 91狠狠操 | 色狠狠一区二区三区香蕉蜜桃 | 国产视频第二页 | 视频一区 在线 | 亚洲欧洲色| 久久亚洲综合伊人 | 综合久久久久久中文字幕 | 69视频免费 | 欧美激情视频网址 | 伊人久久99 | 久久久91精品国产一区二区 | 最新国产福利在线观看 | 婷婷三级| 久久久一区二区三区不卡 | 免费看一区二区三区 | 亚洲综合图片小说区热久久 | 亚洲综合三区 | 欧美精品成人一区二区视频一 | 91综合久久 | 欧美久草 | 经典欧美gifxxoo | 欧美一级特黄特黄做受 | 美女久久精品 | 久久久久青草线蕉亚洲麻豆 | 在线加勒比 | 国产麻豆综合视频在线观看 | 亚洲天堂美女视频 | 四虎影视4hutv最新地址在线 | 国产高清视频免费观看 | 亚洲一区二区免费看 | 性色a v 一区 | 91免费国产 | 开心激情综合网 | 一区二区三区高清不卡 | 特黄视频免费看 | 精品久久久久久乐 | 精品网址 | 精品精品国产高清a毛片牛牛 | 四虎影院色 |