你可以使用 v-on 指令来绑定并监听 DOM 事件。绑定的内容可以是一个当前实例上的方法 (后面无需跟括号) 或一个内联表达式。如果提供的是一个方法,则原生的 DOM event 会被作为第一个参数传入,同时这个 event 会带有 targetVM 属性,指向触发该事件的相应的 viewmodel:
rush:js;">
new Vue({
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 数据对象的别名传进去,会更方便直观一些:
rush:xhtml;">
rush:js;">
new Vue({
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 + ' submit is called!');
}
}
})
当你想要在表达式中访问原来的 DOM event,你可以传递一个 $event 参数进去。
key过滤器
当监听键盘事件时,我们常常需要判断常用的 key code。Vue.js 提供了一个特殊的只能用在 v-on 指令的过滤器:key。它接收一个表示 key code 的参数并完成判断:rush:xhtml;">
系统有很多预设值可以使用,例如:
rush:xhtml;">
预设值为: