当前位置: 首页 > news >正文

详解Vue3中的事件监听方式

在这里插入图片描述

本文主要介绍Vue3中的事件监听方式。

目录

  • 一、v-on指令
  • 二、使用@符号简写
  • 三、事件修饰符
  • 四、动态事件名
  • 五、常见的监听事件
  • 六、自定义事件

在Vue3中,事件监听的方式与Vue2有一些不同。

下面是Vue3中事件监听方式的详细介绍:

一、v-on指令

Vue3中仍然使用v-on指令来绑定事件处理函数。例如,可以使用v-on:click来监听点击事件:

<button v-on:click="handleClick">Click me</button>

在组件的方法中定义事件处理逻辑:

methods: {handleClick() {console.log('Button clicked');}
}

二、使用@符号简写

Vue3中引入了一个新的语法糖,可以使用@符号来代替v-on指令,更加简洁易读。例如,可以使用@click来监听点击事件:

<button @click="handleClick">Click me</button>

三、事件修饰符

Vue3中仍然支持事件修饰符,可以使用.stop、.prevent、.capture和.once来控制事件的行为。例如,可以使用.stop修饰符阻止事件冒泡:

<div @click.stop="handleClick">Click me</div>

四、动态事件名

Vue3中可以使用动态表达式来指定事件名。

例如,可以使用v-bind:动态事件名来动态绑定事件处理函数。动态事件名可以是一个计算属性的结果,或者是一个组件的属性。例如:

<button v-bind:[eventName]="handleClick">{{ buttonText }}</button>
data() {return {eventName: 'click',buttonText: 'Click me',}
},
methods: {handleClick() {console.log('Button clicked');}
}

五、常见的监听事件

在Vue3中,有以下几种常见的事件:

  1. 点击事件(click):当元素被点击时触发。

    <button @click="handleClick">Click me</button>
    
  2. 输入事件(input):当输入框的值发生改变时触发。

    <input type="text" @input="handleInput" />
    
  3. 提交事件(submit):当表单提交时触发。

    <form @submit="handleSubmit"><input type="text" /><button type="submit">Submit</button>
    </form>
    
  4. 鼠标移入事件(mouseenter):当鼠标移入元素时触发。

    <div @mouseenter="handleMouseEnter">Mouse Enter</div>
    
  5. 鼠标移出事件(mouseleave):当鼠标移出元素时触发。

    <div @mouseleave="handleMouseLeave">Mouse Leave</div>
    
  6. 键盘事件(keydown、keyup):当按下或释放键盘上的键时触发。

    <input type="text" @keydown="handleKeyDown" />
    
  7. 聚焦事件(focus):当元素获得焦点时触发。

    <input type="text" @focus="handleFocus" />
    
  8. 失焦事件(blur):当元素失去焦点时触发。

    <input type="text" @blur="handleBlur" />
    

这些只是Vue3中的一些常见事件示例,实际上还有许多其他事件可供使用。

此外,Vue3还支持自定义事件,可以使用$emit方法在组件内触发自定义事件,并在父组件中监听并处理这些事件。

六、自定义事件

Vue3中使用emit方法来触发自定义事件。在父组件中使用v-on监听事件,然后在子组件中使用emit方法触发事件。例如:

<template><button @click="handleClick">Click me</button>
</template><script>
import { defineEmit } from 'vue';export default {emits: ['customEvent'],methods: {handleClick() {this.$emit('customEvent', 'Hello from child component');}}
}
</script>

父组件中监听自定义事件并处理:

<template><ChildComponent @customEvent="handleCustomEvent" />
</template><script>
export default {methods: {handleCustomEvent(message) {console.log(message);}}
}
</script>

在Vue3中,事件处理的方式基本与Vue2保持一致,但引入了一些新的语法糖,如@符号简写和动态事件名。同时,Vue3还支持自定义事件的触发和监听。这些改进使得事件处理更加简洁和灵活。

http://www.lryc.cn/news/271298.html

相关文章:

  • Unity关于easySave2 easySave3保存数据的操作;包含EasySave3运行报错的解决
  • 2022年全球软件质量效能大会(QECon上海站)-核心PPT资料下载
  • 【python报错】UserWarning: train_labels has been renamed targets
  • 算法专题四:前缀和
  • STM32学习笔记十五:WS2812制作像素游戏屏-飞行射击游戏(5)探索动画之帧动画
  • 期末复习(程序设计)
  • html-css-js移动端导航栏底部固定+i18n国际化全局
  • Ubuntu Linux 入门指南:面向初学者
  • 常见算法面试题目
  • PiflowX组件-JDBCWrite
  • 算法导论复习题目
  • HTTPS协议详解
  • 菜鸟学习vue3笔记-vue3 router回顾
  • Mybatis枚举类型处理和类型处理器
  • 2023 NCTF writeup
  • golang的大杀器协程goroutine
  • [Angular] 笔记 9:list/detail 页面以及@Output
  • Linux学习笔记(一)
  • Python 爬虫 教程
  • uniapp原生插件 - android原生插件打包流程 ( 避坑指南一)
  • 搭建maven私服
  • EST-100身份证社保卡签批屏按捺终端PC版web版本http协议接口文档,支持web网页开发对接使用
  • 基于SpringBoot的毕业论文管理系统
  • iToF人脸识别
  • Django开发3
  • MS2358:96KHz、24bit 音频 ADC
  • 【Android12】Android Framework系列---tombstone墓碑生成机制
  • 中间件系列 - Redis入门到实战(原理篇)
  • P2249 【深基13.例1】查找
  • linux常用shell脚本