1.event.target与this的区别 event.target表示发生点击事件的元素; this表示的是注册点击事件的元素 this 等于 e.currentTarget this是所有函数原生具有的.进入函数时,this已经直接有了目标对象. 而e.target通过e再寻找target,中转了一下。所以相比较而言,this的执行效率更高些。 2 $(this.target)与$(this)比较的问题 有人会问为什么$(this.target)!=$(this)? 因为你用了jq来构造两个对象, 所以你最后一步比较的时候, 哪怕是两个对象的内容一模一样, 结果也是不想等的, 对象的比较比较的是指针, 两个指针 不一样所以是不想等的, 简单的说就是 var a = new Object(); var b = new Object();// 这两个对象看起来是一模一样的吧, 但是比较结果依然不想等 你直接比较 this == e.target 这样才能得出正确的结果
1.event.target与this的区别
event.target表示发生点击事件的元素;
this表示的是注册点击事件的元素
this 等于 e.currentTarget
this是所有函数原生具有的.进入函数时,this已经直接有了目标对象.
而e.target通过e再寻找target,中转了一下。所以相比较而言,this的执行效率更高些。
2 $(this.target)与$(this)比较的问题
有人会问为什么$(this.target)!=$(this)?
因为你用了jq来构造两个对象, 所以你最后一步比较的时候, 哪怕是两个对象的内容一模一样, 结果也是不想等的, 对象的比较比较的是指针, 两个指针
不一样所以是不想等的, 简单的说就是
var a = new Object();
var b = new Object();// 这两个对象看起来是一模一样的吧, 但是比较结果依然不想等
你直接比较 this == e.target 这样才能得出正确的结果
额,代码呢。target需要通过形参event才能拿到对象,this则通过类名或者id就能拿到当前触发函数对象
元素嵌套时就不相等了
比如下面结构
楼上的都说了很多,我说还有一种可能是你把this的指向给搞混了。比如你的回调中用了箭头函数或者bind之类的方法生成的回调。