JavaScript 事件 事件绑定 事件解除

 <div></div>函数

//事件绑定的方法

div.onclick = function (){} //function里的this指向DIV
-----------------------------------------------
//obj.addEventListener(type,fn,false) IE9如下不兼容,能够为一个事件绑定多个处理程序 function里的this指向div
div.addEventListener('click',function (){},false);
div.addEventListener('click',test,false);

function test(){
//....
}
---------------------------------------------------
//obj.attachEvent(on+'type',fn) IE独有,一个事件能够绑定多个处理函数 this指向window

div.attachEvent('onclick',function(){
handle.call(div);
})

function haddle(){
this//......

}
//解决this指向的问题
------------------------------------------------
//事件绑定函数封装this

 1 function addEvent(elem,type,handle){
 2         if(elem.addEventListener){
 3             elem.addEventListener(type,handle,false);
 4         }else if(elem.attachEvent){
 5             elem.attachEvent('on'+type,function (){
 6                 handle.call(elem);
 7             })
 8         }else{
 9             elem['on'+type] = handle;
10         }
11         
12     }
13     
14 addEvent(div,click,fn);

//解除事件绑定
elem.onclick = null;
elem.removeEventListener(type,fn,false);
elem.dettachEvent('on'+type,fn);
spa

相关文章
相关标签/搜索