Vue.js 基础学习 v-on 指令

在前面的基础学习中已经写了v-for和v-bind两个指令

今天学习v-on指令

v-on指令:用来绑定事件的
body中

<div id="app">

</div>

script中

var app = new Vue({
el : '#app',
methods : {

}
})

在div app中加入一个button并绑定一个点击事件

<button v-on:click="onClick">点我</button>

在js中的methods 中加入一个onClick

methods : {
onClick : function(){
console.log("clicked");
},    //每次添加一个成员就在后面加一个,方便添加新的
}

这时,在浏览器中点击按钮console会打印clicked,绑定click成功
我们还可以同时绑定多个事件

<button v-on='{mouseenter:onEnter,mouseleave:onOut}' v-on:click="onClick">点我</button>

上面我们通过对象的方式绑定多个事件,对象中的键是事件的名称 值是methods中的成员属性方法

methods : {
onClick : function(){
console.log("clicked");
},
onEnter : function(){
console.log("mouseenter");
},
onOut : function(){
console.log("mouseout");
},
}

这时,在浏览器中将鼠标移入button console会打印mouseenter 移出button console会打印mouseout

在div app中添加一个form 为form绑定一个提交事件

<form v-on:submit="onSubmit">
<input type="text"><br />
<input type="submit" value="提交">
</form>

在method中添加onSubmit

onSubmit:function() {
console.log("submitted");
},

绑定完发现在运行时无法在console中打印出submitted 原因是每次提交页面都会刷新

避免刷新的方法有两种
第一种onSubmit传递参数$event

<form v-on:submit="onSubmit($event)">

然后

onSubmit:function(e) {
e.preventDefault();
console.log("submitted");
},

这样我们就能打印出submitted而不刷新页面了

然而vue为我们提供了更加简单的方法那就是

<form v-on:submit.prevent="onSubmit">

而onSubmit不改动

onSubmit:function() {
console.log("submitted");
},

vue还提供了subnit.stop 用来停止冒泡

keyUp事件也提供了keyUp.enter只有enter按下时才触发

<form v-on:keyUp.enter="onkeyUpenter" v-on:submit.prevent="onSubmit">

在method中添加

onkeyUpenter : function() {
console.log("keyenterpressed");
},

只有按下enter时才会在console中打印

由于v-on很常用所以它也有一个简写方式@如 @click="onClick" @代表v-on:
在用对象同时绑定多个事件时,不能用@代替v-on。

posted @ 2017-09-02 15:39  hz海内存知己  阅读(37828)  评论(0编辑  收藏  举报