Vue.JS入门教程之事件监听
你可以使用v-on指令来绑定并监听DOM事件。绑定的内容可以是一个当前实例上的方法(后面无需跟括号)或一个内联表达式。如果提供的是一个方法,则原生的DOMevent会被作为第一个参数传入,同时这个event会带有targetVM属性,指向触发该事件的相应的ViewModel:
<divid="demo"> <av-on="click:onClick">触发一个方法函数</a> <av-on="click:n++">触发一个表达式</a> </div>
newVue({
el:'#demo',
data:{
n:0
},
methods:{
onClick:function(e){
console.log(e.targetVM.n);
console.log(e.target.tagName);//"A"
console.log(e.targetVM===this);//true
}
}
});
执行表达式
当在v-repeat里使用v-on时,targetVM显得很有用,因为v-repeat会创建大量子ViewModel。但是,通过执行表达式的方式,把代表当前ViewModel数据对象的别名传进去,会更方便直观一些:
<ulid="list">
<liv-repeat="iteminitems"v-on="click:toggle(item)">
{{item.text}}
</li>
<buttonv-on="click:submit('hello!',$event)">Submit</button>
</ul>
newVue({
el:'#list',
data:{
items:[
{text:'one',done:true},
{text:'two',done:false}
]
},
methods:{
toggle:function(item){
console.info(item.done);
item.done=!item.done;
console.info(item.done);
},
submit:function(msg,e){
e.stopPropagation();
console.info(msg+'submitiscalled!');
}
}
})
当你想要在表达式中访问原来的DOMevent,你可以传递一个$event参数进去。
key过滤器
当监听键盘事件时,我们常常需要判断常用的keycode。Vue.js提供了一个特殊的只能用在v-on指令的过滤器:key。它接收一个表示keycode的参数并完成判断:
<!--只有当keyCode等于13时才调用方法--> <inputv-on="keyup:mySubmit|key13">
系统有很多预设值可以使用,例如:
<!--效果同上--> <inputv-on="keyup:submit|key'enter'">
预设值为:entertabdeleteescupdownleftrightspace
为什么在HTML中使用监听器
你可能会注意到整个事件监听的方式违背了“separationofconcern”的传统理念。不必担心,因为所有的Vue.js事件处理方法和表达式都严格绑定在当前视图的ViewModel上,它不会导致任何维护困难。实际上,使用v-on还有更多好处:
它便于在HTML模板中轻松定位JS代码里的对应方法实现。
因为你无须在JS里手动绑定事件,你的ViewModel代码可以是非常纯粹的逻辑,和DOM完全解耦。这会更易于测试。
当一个ViewModel被销毁时,所有的事件监听都会被自动移除。你无须担心如何自行清理它们。
本文已被整理到了《Vue.js前端组件学习教程》,欢迎大家学习阅读。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。