第一话:IE中用DOM方法绑定事件

工作比较忙,但是也一定要抽时间出来提升一下自己的基本功,只有技术实力到位,才能为公司和个人创造更多的价值。下面进入主题:

IE中事件监听比较容易用到,但是由它所引出的一个关于this的问题,不得不着重的去思考和记录一下。

一、浏览器中不同的事件监听/绑定(个人感觉用监听比较通俗易懂):

//IE
element.attachEvent("event",functionname);                    //参数:1,表示监听的事件,需要在事件前加on(onclick,onfocus,onkeyevent……)2,响应事件时候所要执行的方法。
//Chrome and FireFox
element.addEventListener("event",functionname,false);         //参数:1和2同上(事件前不加on),3,是一个boolean,表示事件处理器是否启用事件捕捉。

二、既然不同的浏览器中的监听事件都清楚了,那我们有必要整合一种兼容性的方法出来。

//封装可重用的代码
functioin addListener(element,event,listener){
    if(element.addEventListener){                              //通过去区别该浏览器是否支持该方法,而执行不同的监听事件
        element.addEventListener(event,listener,false);
    }else if(element.attachEvent){
        element.attachEvent("on"+event,listener);
    }
}

//这样就可以监听事件了在ie和webkit等内核浏览器下都ok
addListener(window,"keydown",HandleKeyDown);
addListener(window,"load",init);
addListener(document.getElementById("link"),"click",onclick);

三,通用的方法,写好了,但是如果想用this的话,会遇到一点麻烦。思考如下代码:

addListener(document.getElementById("mylink"),"click",foo(){
    alert(this.href);
})

我们预期的效果是输出mylink元素的href,但在IE下事实是这样么?

重点:当执行某个方法的时候,this所指向函数的拥有者。

例如:

//方法1
function myFuc(){
    alert(this);                        //这时候this指向window对象
}

//方法2
var el = function(){
    alert(this);                       //this-->window对象
} 

//方法2
var el.method = function(){
    alert(this);                       //this-->el对象
}
//方法2
var el = function(){
    alert(this);                       //this-->window对象
} 

//方法2
var el.method = function(){
    alert(this);                       //this-->el对象
}

这样比较容易理解,但将一个对象的方法传递给另外的函数时候,那结果就匪夷所思了:

function myFunc(func){
    func()
}

var el.method = function(){
    alert(this);
}

myFunc(el.method);               //参数只是el.method的一个引用,并非整个el对象,所以这个时候this是window,因为myFunc属于window

//这样有歧义的用法,最好了解透彻,然后根据需求设计。我们的本意其实可以用另外的一种方式实现。

function myFunc(func){
    func.call(el)                      //call方法:允许一个方法在另一个对象中执行(抽象),简单的说,其实是,func是在el对象的基础上执行。等价el.method();
}

所以调用call方法之后,此刻this又指向了el对象。

四,修改addListener方法

functioin addListener(element,event,listener){
    if(element.addEventListener){
        element.addEventListener(event,listener,false);
    }else if(element.attachEvent){
        element.attachEvent("on"+event,function(){listener.call(element)});
    }
}

五,事件既然可以监听,那就可以取消监听

//webkit
var bKeyEvent = false;

function HandleKeydown(evt){
       if(bKeyEvent){
            //todo
        } else {
             evt.preventDefault()
         }
}
addListener(window,"keydown",HandleKeydown);

//IE
var bKeyEvent = false;

function HandleKeydown(evt){
       if(bKeyEvent){
            //todo
        } else {
             evt.returnValue = false
         }
}
addListener(window,"keydown",HandleKeydown);

另外一种方法(更简洁直观):

//webkit
window.removeEventListener("keydown",HandleKeyDown,false);
//IE
window.detachEvent(("keydown",HandleKeyDown);

第一话:IE中用DOM方法绑定事件

时间: 2024-07-30 20:31:53

第一话:IE中用DOM方法绑定事件的相关文章

Js为Dom元素绑定事件须知

为异步加载的Dom 元素绑定事件必须在加载完成之后绑定: $('body').load('LearnClickBinding.ashx');$('a').click(function () { alert('I was clicked!'); }); 上面的绑定是无效的,因为异步加载需要时间,而在获取元素之前,早已执行了$('a').click();方法,所以绑定失败. 正确的做法是,等待元素加载完后再执行 $('a').click(); $('body').load('LearnClickBi

随笔一个dom节点绑定事件

以下利用jquery说明: js中,给一个dom节点绑定事件再平常不过了.这里说下,如果dom经常发生变化的话,给这个dom绑定事件的情况. 比如代码如下: li的节点,绑定了事件:点击会打出来里头的html内容. button点击事件:会生成一个li节点. 1 <html> 2 <head> 3 <meta charset="UTF-8"> 4 </head> 5 <body> 6 <ul class="ul

Chrome插件Visual Event查看Dom元素绑定事件的利器

找这工具找了好久,统一找着了,开发人员不可多得的好东东,收藏做一下分享. 用Chrome插件Visual Event查看Dom绑定的事件 Visual Event简介 Visual Event是一个开源 Javascript 书签,能提供绑定在DOM元素上的事件调试信息.Visual Event能显示如下信息: 1.哪一个元素有事件绑定 2.某元素上绑定的事件类型 3.事件触发后运行的代码段 4.定义绑定函数的源文件和行号(仅限于WebKit和Opera浏览器) 除了对调试你自己的代码大有用途,

【JS 设计模式 】门面模式之DOM元素绑定事件

门面模式的作用:一是简化类的接口,通过用一个接口(函数或方法)来封装复杂的逻辑代码从而客户端可以使用一个接口来调用它:二是消除类与使用它的客户代码之间的耦合,使客户代码和复杂的逻辑代码分离,也就是耦合: ?在何种情况下会使用:1)为一个复杂子系统提供一个简单接口.2)提高子系统的独立性.3)在层次化结构中,使用Facade模式定义系统中每一层的入口,使它们各尽其责. 用绑定事件来举例门面模式,IE浏览器和其它(火狐.谷歌)浏览器在对html元素绑定事件上是有区别的. ie绑定代码: var bu

jQuery on()方法绑定事件

jQuery绑定事件 语法:$(selector).on(event,childselector,function(){}); 可以为自身的加事件(一个或多个)  也可以为其子元素加事件(一个或多个) 自己加事件例子: $('ul').on('click',function(event){ alert(this); }); 为子元素加事件例子  相当于事件委托  应用场景 比如dom数没有加载完的时候是无法给标签元素添加时间的  但是可以使用事件委托的办法 委托给body $('body').o

DOM元素绑定事件的参数说明

当绑定在DOM元素上的事件处理写在标签中时,有两个已知常量,其名称被占用,分别是:event:表示事件对象, this:表示元素本身注意:若调用的脚本方法需要用到这两个对象,必须作为参数传递进来 当绑定在DOM元素上的事件处理未写在标签中时,而是纯粹通过脚本绑定,那么:脚本方法第1个形参:自动表示事件对象, this:自动表示元素本身注意:脚本方法的第1个形参名称无论是写event,还是x,或者a,都表示为Event事件对象,若没有写形参名称,还可通过arguments[0]来获取该Event事

Jquery中的bind()方法绑定事件总结

bind()功能是为了每一个选择元素的时间绑定一个或多个处理函数: 语法格式:bind(type,[data],fn); 参数说明:   type: type表示添加一个或多个的事件,如:click,dbclick,change,load,resize,scroll,unload,blur,focus,mousemove,mouseout,mouseup,mousedown,mousemove,mouseenter,mouseleave,select.submit,keydown,keypres

Jquery on方法绑定事件后执行多次

$("#btnOktcHc").on("click", function () {}); $("#btnOktcHc").off("click"); on 对同一个元素多次绑定同一个事件的时候,这个事件就会执行多次.

jQuery之方法绑定(事件注册)代码小结

1.最直接的模式,直接将一个function对象传入方法函数,如下面的click(),好处坏处一看便知 $("#btnComfirmChooseCompany").click(function () { var companyName = ""; var companyID = ""; var hasChecked = false; var allCheckbox = $("input[name='companyID']");