探究绑定事件的this指向以及event传参的小问题
this指向
直接上代码,凑合着看
<input type="button" onclick="page()" value="点我"></input>
<input type="button" value="点我2号" id="btn"/>
<input type="button" value="点我3号" id="btn2"/>
<input type="button" value="点我测试addEventListener传参" id="btn-parem"/>
<input type="button" value="我是ie终结者,赶紧点我" id="ie-end">
<script>
//该函数用于测试页面上的this对象
function page(){
console.log(this==window)
// true 说明页面上绑定的事件的作用域都是window,这样很不好,因为有时候我们是希望我们的this值就是当前的对象而不是window
}
var btn=document.getElementById("btn");
btn.onclick=function(){
console.log(this);
// 这个时候就正常了,输出的this指向的是当前的input对象
};
var btn2=document.getElementById("btn2");
function btnClick(){
console.log(this)
// 很明显这也是正常的
}
btn2.addEventListener("click",btnClick,false);
// 关于addEventListener我们再扯一个,怎么往addEventListener里面的函数传参
var btnParem=document.getElementById("btn-parem")
function pare(a,b){
console.log(a+b)
}
// btnParem.addEventListener("click",pare(1,2),false)
// 亲,很明显这种写法是不行的,因为我还没点击事件就已经自动执行了
btnParem.addEventListener("click",function(){pare(1,9)},false)
// 注意,关于attachEvent该事件是ie特有的绑定事件方式,同时该事件以及渐渐的被抛弃,在最新的ie edge中已经没有了该事件转而支持addEventListener
// 同时,在ie 9 10中也已经支持addEventListener事件
var ieEnd=document.getElementById("ie-end")
function ending(){
console.log(this)
// 在支持该事件的浏览器下输出window
}
ieEnd.attachEvent("onclick",ending)
</script>
怎么向addEventListener中传入event对象
<input type="button" id="btn" value="测试"/>
var btn=$("#btn");
btn.onclick=function(e){
console.log(e);
}
这样的写法是正常的,可以正确的传入e,换成addEventListener的情况就是这样写
function func(e){
console.log(e);
}
btn.addEventListener("click",func,false)
此时可以看到,我们并没有显式的向func中传入参数e。那么当我们想传参的时候应该怎么写呢
function func(e,a,b){
console.log(e);
console.log(a+b);
}
btn.addEventListener("click",function(e){
func(e,1,2);
},false);
这就是正确的写法,使用一个匿名函数包住我们的func,同时在匿名函数中传入参数e
探究绑定事件的this指向以及event传参的小问题的更多相关文章
- 使用call、apply和bind解决js中烦人的this,事件绑定时的this和传参问题
1.什么是this 在JavaScript中this可以是全局对象.当前对象或者任意对象,这完全取决于函数的调用方式,this 绑定的对象即函数执行的上下文环境(context). 为了帮助理解,让我 ...
- 使用addEventListener绑定事件是关于this和event记录
DOM元素使用addEventListener绑定事件的时候经常会碰到想把当前作用域传到函数内部,可以使用以下两种放下: var bindAsEventListener=function (objec ...
- html 中绑定事件 this的指向
var m=function(){ alert(2); } var obj={ A:function(){ }, m:function(){ ...
- jQuery 为动态添加的元素绑定事件
在使用jquery的方式为元素绑定事件时,我经常使用bind或者click,但这只能为页面已经加载好的元素绑定事件.像需要用ajax的方式请求远程数据来动态添加页面元素时,显然以上几种绑定事件的方式是 ...
- jQuery绑定事件的on()
jQuery绑定事件 语法:$(selector).on(event,childselector,function(){}); 可以为自身的加事件(一个或多个) 也可以为其子元素加事件(一个或多个) ...
- Chrome插件Visual Event查看Dom元素绑定事件的利器
找这工具找了好久,统一找着了,开发人员不可多得的好东东,收藏做一下分享. 用Chrome插件Visual Event查看Dom绑定的事件 Visual Event简介 Visual Event是一个开 ...
- jquery 绑定事件 获取方式 --------------data event 获取
//绑定事件 bind event $("body").on("click",function(){ console.log("in") } ...
- 冒泡,setinterval,背景图的div绑定事件,匿名函数问题探究
1.会冒泡到兄弟元素么? $(function(){ $("#a").click(function(){alert("a")}) $("#b" ...
- JavaScript中绑定事件监听函数的通用方法addEvent() 和 事件绑定之bindEvent()与 unBindEvent()函数
下面绑定事件的代码,进行了兼容性处理,能够被所有浏览器支持: function addEvent(obj,type,handle){ try{ // Chrome.FireFox.Opera.Safa ...
随机推荐
- GDI+入门——带你走进Windows图形的世界
一.GDI+基础 1.GDI+简单介绍 GDI+是微软的新一代二维图形系统,它全然面向对象,要在Windows窗口中显示字体或绘制图形必需要使用GDI+.GDI+提供了多种画笔.画刷.图像等图形对象, ...
- LKD3
第三章 进程1. Unix操作系统的抽象:进程和文件2. 进程包括两个因素:可运行代码,和资源(打开的文件,挂起的信号,内核内部数据,处理器状态,地址空间)3. 线程是进程中活动的对象.4. 线程有独 ...
- Oracle查询数据中占用空间最大的表
--第一步,查询istaudit数据库文件ID,文件路径 select file#,name from v$datafile where lower(name) like '%istaudit.dbf ...
- iOS开发之第三方登录QQ -- 史上最全最新第三方登录QQ方式实现
项目地址 : https://github.com/zhonggaorong/QQLoginDemo/tree/master 最新版本的qq登录实现步骤实现: 1. 首先,你需要去向腾讯申请账号. ...
- JavaSE学习总结第06天_Java语言基础2 & 面向对象1
06.01 二维数组概述和格式1的讲解 二维数组概述:二维数组其实就是一个元素为一维数组的数组 格式1:数据类型[][] 变量名 = new 数据类型[m][n]; m表示这个二维数组有多少个一维 ...
- js基础之冒号
js中冒号的作用有两种, 转自:http://www.kqiqi.com/knowledge/web-based/506.html 一.?: 操作符 a = expression ? b : c;如果 ...
- 在QuartusII 中使用tcl对工程进行复制——半自动
最近在看coyoo的博客,加上手上有一本coyoo老师的书籍.本人是脚本小白,怎么看都没有看懂这个自动化是怎么实现的. 先说我的半自动化,后面在说我对自动化的一点疑惑—— 目前没有实现 目录环境: 首 ...
- Log4J logger图片
- C# 操作Excel (二)
根据翻阅LTP.Net知识库系列之四中Office操作功能: 一.记录常用如下 (1)“在自己的程序中宿主Office”的意思就是在我们自己开发的应用程序的窗体上,显示一个就像Office应用程序那样 ...
- jQuery遍历table
1. $("table").find("tr").each(function(){ $(this).find("td").each(func ...