【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
相关文章
|
2月前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
147 64
|
2月前
|
JavaScript 前端开发 API
Vue 3 中 v-model 与 Vue 2 中 v-model 的区别是什么?
总的来说,Vue 3 中的 `v-model` 在灵活性、与组合式 API 的结合、对自定义组件的支持等方面都有了明显的提升和改进,使其更适应现代前端开发的需求和趋势。但需要注意的是,在迁移过程中可能需要对一些代码进行调整和适配。
117 60
|
13天前
|
JavaScript API 数据处理
vue3使用pinia中的actions,需要调用接口的话
通过上述步骤,您可以在Vue 3中使用Pinia和actions来管理状态并调用API接口。Pinia的简洁设计使得状态管理和异步操作更加直观和易于维护。无论是安装配置、创建Store还是在组件中使用Store,都能轻松实现高效的状态管理和数据处理。
45 3
|
2月前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
41 8
|
2月前
|
存储 JavaScript 数据管理
除了provide/inject,Vue3中还有哪些方式可以避免v-model的循环引用?
需要注意的是,在实际开发中,应根据具体的项目需求和组件结构来选择合适的方式来避免`v-model`的循环引用。同时,要综合考虑代码的可读性、可维护性和性能等因素,以确保系统的稳定和高效运行。
34 1
|
2月前
|
JavaScript
Vue3中使用provide/inject来避免v-model的循环引用
`provide`和`inject`是 Vue 3 中非常有用的特性,在处理一些复杂的组件间通信问题时,可以提供一种灵活的解决方案。通过合理使用它们,可以帮助我们更好地避免`v-model`的循环引用问题,提高代码的质量和可维护性。
45 1
|
2月前
|
JavaScript
在 Vue 3 中,如何使用 v-model 来处理自定义组件的双向数据绑定?
需要注意的是,在实际开发中,根据具体的业务需求和组件设计,可能需要对上述步骤进行适当的调整和优化,以确保双向数据绑定的正确性和稳定性。同时,深入理解 Vue 3 的响应式机制和组件通信原理,将有助于更好地运用 `v-model` 实现自定义组件的双向数据绑定。
|
2月前
|
JavaScript 索引
Vue 3.x 版本中双向数据绑定的底层实现有哪些变化
从Vue 2.x的`Object.defineProperty`到Vue 3.x的`Proxy`,实现了更高效的数据劫持与响应式处理。`Proxy`不仅能够代理整个对象,动态响应属性的增删,还优化了嵌套对象的处理和依赖追踪,减少了不必要的视图更新,提升了性能。同时,Vue 3.x对数组的响应式处理也更加灵活,简化了开发流程。
|
2月前
|
JavaScript 前端开发 API
从Vue 2到Vue 3的演进
从Vue 2到Vue 3的演进
48 0
|
2月前
|
JavaScript 前端开发 API
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
67 0

热门文章

最新文章