vue指令之v-on

v-on的作用是给元素添加事件监听,可以简写为@

JavaScript的元素的事件监听都可以再vue中使用                     

                    原生的JavaScript的事件监听:

事件名称

方法

点击

onclick

双击

ondblclick

鼠标移上

onmouseenter

鼠标离开

onmouseleave

鼠标滑过

onmousemove

鼠标移除

onmouseout

失去焦点

onblur

聚焦

onfocus

键盘事件

onkeydown

上表的方法都是原生的JavaScript的事件方法,在vue中的使用是一律去除on,然后 添加v-on:或者@

 1     <div id="app" >
 2         <h1>{{a}}</h1>    
 3         <button @click="add">点击加1</button>
 4         <button v-on:click="minus">点击减1</button>
 5     </div>
 6     <script src = "js/vue.js"></script>
 7     <script>
 8       var vue = new Vue({
 9                el: "#app",
10                data: {
11                    a: 100
12                },
13                methods:{
14                    add() {
15                        this.a++
16                        console.log(this.a)
17                    },
18                    minus() {
19                        this.a --
20                        console.log(this.a)
21                    }
22                }
23              })
24     </script>

此时打开浏览器可以看到:

下面的代码是错误的,因为vue没有定义对应的方法名称:

 1 var vue = new Vue({
 2     el: "#app",
 3     data: {
 4         a: 100
 5     },
 6     add() {
 7         this.a++
 8     },
 9     minus() {
10         this.a --
11     }
12 })

打开network面板会看到:

原生的JavaScript的事件方法是不能和vue混用的

 

此时会报错

同名方法会有覆盖情况,后写方法会覆盖先写的方法:

 1    var vue = new Vue({
 2                el: "#app",
 3                data: {
 4                    a: 100
 5                },
 6                methods:{
 7                    add() {
 8                        this.a++
 9                    },
10                    add() {
11                        this.a += 3
12                    },
13                    add() {
14                        this.a += 5
15                    }
16                 }
17              })

我们可以看到以4的基数进行相加:

 

 

 

方法中是可以传入参数的:

 1     <div id="app" >
 2         <h1>{{a}}</h1>    
 3         <button @click="add(5)">点击加1</button>
 4     </div>
 5     <script src = "js/vue.js"></script>
 6     <script>
 7       var vue = new Vue({
 8                el: "#app",
 9                data: {
10                    a: 100
11                },
12                methods:{
13                    add(num) {
14                        this.a+= num
15                        console.log(this.a)
16                    }
17                 }
18              })
19     </script>

我们可以看到以5的基数进行相加:

 

 我们可以查看方法中的事件参数

 1 methods:{  add(event) {  console.log(event)  } 

 

 

posted @ 2021-09-13 00:00  keyeking  阅读(360)  评论(0编辑  收藏  举报