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

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方法绑定事件的更多相关文章

  1. Js为Dom元素绑定事件须知

    为异步加载的Dom 元素绑定事件必须在加载完成之后绑定: $('body').load('LearnClickBinding.ashx');$('a').click(function () { ale ...

  2. 随笔一个dom节点绑定事件

    以下利用jquery说明: js中,给一个dom节点绑定事件再平常不过了.这里说下,如果dom经常发生变化的话,给这个dom绑定事件的情况. 比如代码如下: li的节点,绑定了事件:点击会打出来里头的 ...

  3. mui-当使用addeleventlisener()方法绑定事件时选择器无法绑定事件

    在mui中绑定事件不能用jQuery或mui(“#XX”)的形式选取某个元素,而是document.getelementbyid()的形式 mui(“#XX”)可以使用on方法绑定事件

  4. attachEvent方法绑定事件

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

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

    找这工具找了好久,统一找着了,开发人员不可多得的好东东,收藏做一下分享. 用Chrome插件Visual Event查看Dom绑定的事件 Visual Event简介 Visual Event是一个开 ...

  6. AngularJS如何给动态添加的DOM中绑定事件

    正常情况(即非动态插入 DOM 对象)下,ng-click 这样的指令之所以有效(即点击之后能调用注册在可见作用域里的方法),是因为 angular 在 compiling phase(编译阶段)将宿 ...

  7. jquery给动态添加的dom元素绑定事件

    $('input').click(function () { //处理代码 }); 这只能是对已经加载好的元素定义事件,那些后来添加插入的元素则需要另行绑定,对于页面中动态添加的元素,在页面加载完成后 ...

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

    1.最直接的模式,直接将一个function对象传入方法函数,如下面的click(),好处坏处一看便知 $("#btnComfirmChooseCompany").click(fu ...

  9. jQuery clone()方法绑定事件

    先看如下代码: (function ($) { var div = $("<div></div>").css({width: "100px&quo ...

随机推荐

  1. Sublime + python2.7 + opencv (轻量级开发环境)

    工具: 1. Python2.7,安装完成 2. 相应版本的cv2.pyd,放入到…\Python27\Lib\site-packages\下 3. 下载Sublime Text 3,破解它,网上搜个 ...

  2. 自增自减 a++,++a,a--,--a

    1.自增(++)自减(--)运算符是一种特殊的算术运算符,在算术运算符中需要两个操作数来进行运算,而自增自减运算符是一个操作数. 实例: public class selfAddMinus{ publ ...

  3. PTA 1005 Spell It Right (20)(20 分)水题

    1005 Spell It Right (20)(20 分) Given a non-negative integer N, your task is to compute the sum of al ...

  4. OD 实验(三) - 破解程序的文件验证

    需要破解的程序 双击程序,提示需要许可证文件 逆向程序 用 OD 打开 LoadIconA 为加载图标 LoadCursorA 为加载鼠标 F8 走一下程序 走到了这里,调用了 CreateFileA ...

  5. TypeError: 'ExcelData' object is not iterable

    今天写了个测试的代码,结果在执行test_register.py文件在调用readexcle.py的时候一直报错TypeError: 'ExcelData' object is not iterabl ...

  6. Tkinter Spinbox

    Python - Tkinter Spinbox: Spinbox小部件是一个标准的Tkinter的Entry小窗口部件的变体,它可以用来选择从一个固定的值.   Spinbox小部件是一个标准的Tk ...

  7. Django-2的路由层(URLconf)

    URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表:你就是以这种方式告诉Django,对于客户端发来的某个URL调用哪一段逻辑代码 ...

  8. 呕心沥血Android studio使用JNI实例

    发现网上很多JNI的使用教程,也很详细,不过有的地方有些缺漏,导致很多小问题难以解决的,今天就来总结一下. 准备工作:下载NDK. 简单的说,要用到C/C++,就要用NDK.直接百度搜索然后去官网下载 ...

  9. AJAX跨域调用ASP.NET MVC的问题及解决方案

    AJAX跨域调用ASP.NET MVC的问题及解决方案 问题描述: 解决方法: 只需要在web.config中添加如下标为红色的内容即可: <system.webServer> <h ...

  10. requirejs——config

    config 函数用于requirejs的配置信息.主要包括:baseUrl.paths: 一.baseUrl: 待续