v-on
vue使用v-on指令监听DOM事件,并在触发时运行一些js代码。
- v-on可以接受简单的表达式,比如
counter += 1 。 - 还可以接受一个需要调用的方法名
addOne 。 v-on:click = 'addOne' 可以简写成:@click='addOne' 。
<body>
<div id="root">
<button v-on:click="counter += 1">点我+1</button>
<button v-on:click="addOne">点我+1</button>
<p> {{ counter }}</p>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
<script>
Vue.config.productionTip=false;
var vm = new Vue({
el:"#root",
data:{
counter: 0
},
methods: {
addOne(){
return this.counter += 1;
}
},
})
</script>
</body>
</script>
点击两个按钮得到的结果都是数字加1:
参数的传递
v-on指令在监听DOM事件时,可以传递参数。
<p>
<button v-on:click="say('开心')">开心</button>
<button v-on:click="say('难过')">难过</button>
</p>
<script>
var vm = new Vue({
el:"#root",
methods: {
say(data){
console.log("今天的心情很",data,'!');
}
},
})
</script>
分别点击可以到不同的心情。
事件修饰符
Vue.js 为 v-on 提供了事件修饰符。
- .stop
- .prevent
- .capture
- .self
- .once
- .passive
- 注意:
- 使用修饰符时,顺序很重要;相应的代码会以同样的顺序产生。因此
- 用 v-on:click.prevent.self 会阻止所有的点击。
- 而 v-on:click.self.prevent 只会阻止对元素自身的点击。
这个知识点官网案例表述得很清晰
<a v-on:click.stop="doThis"></a>
<form v-on:submit.prevent="onSubmit"></form>
<a v-on:click.stop.prevent="doThat"></a>
<form v-on:submit.prevent></form>
<div v-on:click.capture="doThis">...</div>
<div v-on:click.self="doThat">...</div>
<div v-on:scroll.passive="onScroll">...</div>
按键修饰符
在监听键盘事件时,我们经常需要检查详细的按键。Vue 允许为 v-on 在监听键盘事件时添加按键修饰符:
- 只有在
key 是 Enter 时调用 vm.submit() : <input v-on:keyup.enter="submit"> - 处理函数只会在 $event.key 等于 PageDown 时被调用:
<input v-on:keyup.page-down="onPageDown"> - Vue 提供了绝大多数常用的按键码的别名:
.enter .tab .delete (捕获“删除”和“退格”键).esc .space .up .down .left .right
|