|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
就安全性而言,net网页编程已经远远低于VB.NET,更无法与安全性著称的C#相比。Click、touch、load、drag、change、input、error、risize—这些都是冗杂的DOM(文档对象模子)事务列表的一部分。事务能够在文档(Document)布局的任何部分被触发,触发者能够是用户操纵,也能够是扫瞄器自己。事务并非只是在一处被触发和停止;他们在全部document中活动,具有它们本人的性命周期。而这个性命周期让DOM事务有更多的用处和可扩大性。
作为一个开辟职员,我们必需要了解DOM事务是怎样事情的,然后才干更好的把握它,使用它们潜伏的上风,开辟出更高交互性的介入体验(engagingexperiences)。
反不雅我做前端开辟的这么长工夫里,我以为我历来没有看到过一个关于DOM事务是怎样事情的较为间接正确的注释。明天我的方针就是在这个课题上给人人一个明晰的先容,让人人可以更疾速的懂得它。我起首会先容DOM事务的基础利用体例,然后会深切发掘事务外部的事情机制,注释我们怎样利用这些机制来办理一些罕见的成绩。
监听事务
在已往,支流扫瞄器之间关于怎样给DOM节点增加事务监听有着很年夜的纷歧致性。jQuery如许的前端库为我们封装和笼统了这些差别举动,为事务处置带来了极年夜的便当。
现在,我们正一步步走向一个尺度化的扫瞄器时期,我们能够加倍平安地利用官方标准的接口。为了复杂起见,这篇文章将次要先容在古代扫瞄器中怎样办理事务。假如你在为IE8大概更低版本写JavaScript,我会保举你利用polyfill大概一些框架(如jQuery)来办理事务监听。
在JavaScript中,我们利用以下的体例为元素增加事务监听:
1
element.addEventListener(<event-name>,<callback>,<use-capture>);
- event-name(string)
这是你想监听的事务的称号或范例。它能够是任何的尺度DOM事务(click,mousedown,touchstart,transitionEnd,等等),固然也能够是你本人界说的事务称号(我们会在前面先容自界说事务相干内容)。
- callback(function)(回调函数)
这个函数会在事务触发的时分被挪用。响应的事务(event)对象,和事务的数据,会被作为第一个参数传进这个函数。
- use-capture(boolean)
这个参数决意了回调函数(callback)是不是在“捕捉(capture)”阶段被触发。不必忧虑,我们稍后会对此做具体的注释。
1
2
3
4
5
6
7
8
varelement=document.getElementById(element);
functioncallback(){
alert(Hello);
}
//Addlistener
element.addEventListener(click,callback);
Demo:addEventListener
移除监听
移除不再利用的事务监听是一个最好理论(特别关于长工夫运转的Web使用)。我们利用element.removeEventListener()办法来移除事务监听:
1
element.removeEventListener(<event-name>,<callback>,<use-capture>);
可是removeElementListener有一点必要注重的是:你必需要有这个被绑定的回调函数的援用。复杂地挪用element.removeEventListener(click);是不克不及到达想要的效果的。
实质下去讲,假如我们思索要移除事务监听(我们在长工夫运转(long-lived)的使用中必要用到),那末我们就必要保存回调函数的句柄。意义就是说,我们不克不及利用匿名函数作为回调函数。
1
2
3
4
5
6
7
8
9
varelement=document.getElementById(element);
functioncallback(){
alert(Helloonce);
element.removeEventListener(click,callback);
}
//Addlistener
element.addEventListener(click,callback);
Demo:removeEventListener
保护回调函数高低文
一个很简单碰到的成绩就是回调函数没有在料想的运转高低文被挪用。让我们看一个复杂的例子来注释一下:
1
2
3
4
5
6
7
8
9
10
11
12
13
varelement=document.getElementById(element);
varuser={
firstname:Wilson,
greeting:function(){
alert(Mynameis+this.firstname);
}
};
//Attachuser.greetingasacallback
element.addEventListener(click,user.greeting);
//alert=>Mynameisundefined
Demo:Incorrectcallbackcontext
利用匿名函数(AnonymousFunctions)
我们但愿回调函数中可以准确的输入”MynameisWilson”。现实上,了局确是”Mynameisundefined”。为了使得this.firstName可以前往”Wilson”,user.greeting必需在user对象的高低文情况(context)中被实行(这里的运转高低文指的是.号右边的对象)。
当我们将greeting函数传给addEventListener办法的时分,我们传送的是一个函数的援用;user响应的高低文并没有传送已往。运转的时分,这个回调函数实践上是在element的高低文中被实行了,也就是说,在运转的时分,this指向的是element,而不是user。以是this.firstName是undefined。
有两种体例能够制止这类高低文毛病的成绩。第一种办法,我们能够在一个匿名函数外部挪用user.greeting()办法,从而取得准确的函数实行高低文(user)。
1
2
3
4
element.addEventListener(click,function(){
user.greeting();
//alert=>MynameisWilson
});
Demo:Anonymousefunctions
利用Function.prototype.bind
上一种体例并非十分好,由于我们不克不及取得回调函数的句柄以便前面经由过程.removeEventListener()移除事务监听。别的,这类体例也对照丑恶。。我更喜好利用.bind()办法(做为ECMAScript5的尺度内建在一切的函数对象中)来天生一个新的函数(被绑定过的函数),这个函数会在指定的高低文中被实行。然后我们将这个被绑定过的函数作为参数传给.addEventListener()的回调函数。
<p>1
2
3
4
5
6
//Overwritetheoriginalfunctionwith
//oneboundtothecontextofuser
user.greeting=user.greeting.bind(user);
<p> |
|