【Vue3从零开始-第二章】2-8 事件绑定详解

简介: 【Vue3从零开始-第二章】2-8 事件绑定详解

]UWOD(KIB9LJS9~S[T{QHM9.png


前言


上一篇文章中,详细讲过了vue的列表循环渲染,今天我们继续深入了解一下vue的事件绑定。大家在之前的例子中也有用过,下面我们就详细的讲解一下。


回顾


在第一章中,我们有写过一个计数器的小例子,主要就是通过点击按钮,触发事件之后给data函数里面的counter值累加1


<script>
    const app = Vue.createApp({
        data(){
            return {
                counter: 0
            }
        },
        methods: {
            handleBtnClick(){
                this.counter += 1
            }
        },
        template: `
            <div>
                {{counter}}
                <button v-on:click="handleBtnClick">按钮</button>
            </div>
        `
    });
    const vm = app.mount('#root');
</script>
复制代码


`CZ~XXU9J4B$7D9`TS)19(T.png

简写


我们在定义事件的时候,都会在click前面加上v-on:,在vue里面可以将v-on:写成@,也是一样的效果哦。


v-on:click 相当于 @click


event


在原生的js里面,我们可以通过给元素绑定事件之后,获取到一些原生的数据,那么在vue里面是不是也可以拿到这种类似于原生js里面的数据呢?


methods: {
    handleBtnClick(event){
        console.log('event:', event)
        this.counter += 1
    }
},
template: `
    <div>
        {{counter}}
        <button @click="handleBtnClick">按钮</button>
    </div>
`
复制代码


LWHQ4HH970V1}RNJ$LGKB@M.png


  • 在方法中接收一个event参数,在方法里面打印出来,我们可以在浏览器中看到和原生js对应的一个数据对象了。


比如打印出当前点击的DOM元素。


handleBtnClick(event){
    console.log('event.target:', event.target)
    this.counter += 1
}
复制代码


MCZS3W}9FI@(GYI)VAC(YV9.png


  • 有个疑问,当我们想要在click事件上传递其他参数应该怎么办呢?这个event要怎么获取到呢?


methods: {
    handleBtnClick(num, event){
        console.log('event.target:', event.target)
        this.counter += num
    }
},
template: `
    <div>
        {{counter}}
        <button @click="handleBtnClick(2, $event)">按钮</button>
    </div>
`
复制代码


QE52_}I@3M]T8EC$3]VFI4A.png


  • 可以看到我们在click事件上传递了一个 2$event两个参数给到方法中,这个$event就是vue提供的一个原生event参数了。


事件修饰符


stop


methods: {
    handleBtnClick(){
        this.counter += 1
    },
    handleDivClick(){
        alert('你点击了div元素')
    }
},
template: `
    <div>
        <div @click="handleDivClick">
            {{counter}}
            <button @click="handleBtnClick">按钮</button>
        </div>
    </div>
`
复制代码


{M1KYICU~{EK0Z{3Z~FER~Q.png


  • 当我在button的父元素上也添加一个点击事件之后,会发现在触发按钮点击事件之前还会冒泡到父元素上。


  • 在vue里面,是给了一个修饰符stop来表示阻止事件冒泡。


template: `
    <div>
        <div @click="handleDivClick">
            {{counter}}
            <button @click.stop="handleBtnClick">按钮</button>
        </div>
    </div>
`
复制代码


YY(42U33_Y4KS5NITH)7UGV.png


阻止事件冒泡,是给当前DOM元素上的事件添加stop修饰符,这样就不会触发父级元素的事件效果了。


self


除了上面说的 stop 修饰符之外,还有 self 可以和它有类似的作用,但是self的作用是用来执行当前元素的事件的,除了当前元素之外,包括元素下面的子元素触发事件,都是不会触发到self修饰的元素上。


methods: {
    handleBtnClick(){
        this.counter += 1
    },
    handleDivClick(){
        alert('你点击了div元素')
    }
},
template: `
    <div>
        <div @click.self="handleDivClick">
            {{counter}}
            <button @click="handleBtnClick">按钮</button>
        </div>
    </div>
`
复制代码


1K(Y13$IR4{JY@V6%S@H_MN.png


  • 当我点击按钮时,是不会冒泡到父元素上的事件的,但是当我点击父元素中的内容时,则会触发到该事件。


自身事件触发,只有当点击self修饰的元素下的内容时才会触发,点击其他元素或该元素下的子元素时,也不会触发。


小结


除了上面两个事件修饰符之外,还有以下几种事件修饰符:


  • prevent:阻止默认事件行为


  • capture:捕获模式,和冒泡模式是刚好相反的,冒泡是由内到外触发事件,捕获是从外到内触发事件


  • once:当前事件仅触发一次 由于以上修饰符的演示效果不佳,所以只能留给大家自己去实验一下了。


按键修饰符


<script>
    const app = Vue.createApp({
        methods: {
            handleKeyDown(){
                console.log('敲键盘啦~')
            }
        },
        template: `
            <div>
                <input @keydown="handleKeyDown" />
            </div>
        `
    });
    const vm = app.mount('#root');
</script>
复制代码


HS02D1P6VA4[AP`[TTF[QXK.png


通过keydown事件,可以获取到用户敲击键盘时触发的事件,如果我想要在敲下键盘回车键的时候才触发事件呢?


  • 在原生js里面,可能需要获取event,然后通过event.keycode = 13这样拿到回车键的方法。


  • 在vue里面提供了各个快捷键的修饰符,可以直接获取到对应按键的方法。


<input @keydown.enter="handleKeyDown" />
复制代码


Q[)~NHI`N%J1JM}9E{T$%KD.png


通过在keydown事件后面添加.enter修饰符之后,会发现可以直接替代原生js里面的event.keycode这样的写法。


小结


除了enter之外,还有tabdeleteescupdownleftright等按键修饰符。


鼠标修饰符


当我们单独在DOM元素上添加一个click事件时,默认是点击鼠标左键去触发的,但是vue还提供了其他鼠标事件的修饰符。


<script>
    const app = Vue.createApp({
        methods: {
            handleClick(){
                console.log('鼠标点击')
            }
        },
        template: `
            <div>
                <div @click.right="handleClick">hello</div>
            </div>
        `
    });
    const vm = app.mount('#root');
</script>
复制代码


@7{PGY(SJK~O03{7~{%T@R3.png


鼠标修饰符也是在click事件后面添加的,除了right之外,还有left左键和middle中间滚轮键。


精确修饰符


有时候我们在点击事件时,可能需要判断一下,是否键盘上也按住了ctrl之类的按键。


<script>
    const app = Vue.createApp({
        methods: {
            handleClick(){
                console.log('按住ctrl鼠标点击')
            }
        },
        template: `
            <div>
                <div @click.ctrl="handleClick">hello</div>
            </div>
        `
    });
    const vm = app.mount('#root');
</script>
复制代码


  • 我们在点击事件后面直接添加ctrl之后,当你按下ctrl+c或者其他的ctrl组合键时再点击当前DOM元素,好像也会直接触发这个事件。


  • 如果想要精确到只是按下ctrl,而不是按下ctrl的组合键时,就要用到exact修饰符了。


template: `
    <div>
        <div @click.ctrl.exact="handleClick">hello</div>
    </div>
`
复制代码
  • 由于这个例子无法截取动图,所以需要大家自己手动去尝试了。


总结


本篇文章主要把vue中的事件绑定详细讲解了一下,那我们在回顾一下上面的内容:


  • 事件修饰符:stoppreventcaptureselfoncepassive


  • 按键修饰符:entertabdeleteescupdownleftright


  • 鼠标修饰符:leftmiddleright


  • 精确修饰符:exact
相关文章
|
24天前
|
存储 JavaScript 前端开发
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
【10月更文挑战第21天】 vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
|
21天前
|
JavaScript 前端开发 开发者
Vue 3中的Proxy
【10月更文挑战第23天】Vue 3中的`Proxy`为响应式系统带来了更强大、更灵活的功能,解决了Vue 2中响应式系统的一些局限性,同时在性能方面也有一定的提升,为开发者提供了更好的开发体验和性能保障。
47 7
|
22天前
|
前端开发 数据库
芋道框架审批流如何实现(Cloud+Vue3)
芋道框架审批流如何实现(Cloud+Vue3)
40 3
|
21天前
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
39 1
|
21天前
|
JavaScript 开发者
在 Vue 3 中使用 Proxy 实现数据的双向绑定
【10月更文挑战第23天】Vue 3利用 `Proxy` 实现了数据的双向绑定,无论是使用内置的指令如 `v-model`,还是通过自定义事件或自定义指令,都能够方便地实现数据与视图之间的双向交互,满足不同场景下的开发需求。
42 1
|
23天前
|
前端开发 JavaScript
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
|
24天前
Vue3 项目的 setup 函数
【10月更文挑战第23天】setup` 函数是 Vue3 中非常重要的一个概念,掌握它的使用方法对于开发高效、灵活的 Vue3 组件至关重要。通过不断的实践和探索,你将能够更好地利用 `setup` 函数来构建优秀的 Vue3 项目。
|
27天前
|
JavaScript API
vue3知识点:ref函数
vue3知识点:ref函数
32 2
|
27天前
|
API
vue3知识点:reactive函数
vue3知识点:reactive函数
27 1
|
27天前
|
JavaScript 前端开发 API
vue3知识点:Vue3.0中的响应式原理和 vue2.x的响应式
vue3知识点:Vue3.0中的响应式原理和 vue2.x的响应式
24 0