Vue学习v-on

Vue学习v-on


一、前言

v-on 是 Vue.js 中用于监听 DOM 事件的指令。它可以在触发特定事件时执行指定的 JavaScript 代码或者调用 Vue 实例中的方法。下面我来详细介绍一下 v-on 的用法和示例:

1、基本用法

你可以将 v-on 指令添加到 DOM 元素上,并指定要监听的事件和要执行的事件处理程序。

html 复制代码
<button v-on:click="handleClick">点击我</button>

在这个例子中,v-on:click 指令告诉 Vue.js 监听按钮的点击事件,当按钮被点击时,会执行 Vue 实例中名为 handleClick 的方法。

2、事件修饰符

Vue.js 提供了一些事件修饰符,用于处理特定的事件行为。例如,.stop 用于阻止事件冒泡,.prevent 用于阻止默认事件行为,.capture 将事件侦听器添加到捕获阶段等。

html 复制代码
<form v-on:submit.prevent="handleSubmit">
  <!-- 阻止表单默认提交行为 -->
  <button type="submit">提交</button>
</form>

3、事件对象

在事件处理程序中,你可以通过特殊变量 $event 访问原生 DOM 事件对象。

html 复制代码
<button v-on:click="handleClick($event)">点击我</button>
javascript 复制代码
methods: {
  handleClick(event) {
    console.log(event); // 输出原生 DOM 事件对象
  }
}

4、动态事件名

你也可以使用动态事件名来监听事件。

html 复制代码
<button v-on:[eventName]="handleClick">点击我</button>
javascript 复制代码
data() {
  return {
    eventName: 'click'
  };
},
methods: {
  handleClick() {
    console.log('按钮被点击了');
  }
}

5、事件修饰符和按键修饰符

除了一般的事件修饰符外,Vue.js 还提供了按键修饰符,用于监听键盘事件。

html 复制代码
<input v-on:keyup.enter="submit">

在这个例子中,keyup.enter 表示监听键盘的回车键,并在按下回车键时执行 submit 方法。

6、自定义事件

除了原生 DOM 事件外,Vue.js 还支持自定义事件。你可以使用 $emit 方法在子组件中触发自定义事件,并在父组件中使用 v-on 监听这些事件。

二、总结

v-on 指令是 Vue.js 中用于监听 DOM 事件的主要方式,它可以监听原生 DOM 事件和自定义事件,并支持事件修饰符和按键修饰符,以及动态事件名的绑定。

相关推荐
Mr Xu_4 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠4 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
ASKED_20195 小时前
Langchain学习笔记一 -基础模块以及架构概览
笔记·学习·langchain
(❁´◡`❁)Jimmy(❁´◡`❁)5 小时前
Exgcd 学习笔记
笔记·学习·算法
未来之窗软件服务6 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
云小逸7 小时前
【nmap源码学习】 Nmap网络扫描工具深度解析:从基础参数到核心扫描逻辑
网络·数据库·学习
phltxy7 小时前
Vue 核心特性实战指南:指令、样式绑定、计算属性与侦听器
前端·javascript·vue.js
Byron07078 小时前
Vue 中使用 Tiptap 富文本编辑器的完整指南
前端·javascript·vue.js
程序员老刘·9 小时前
Android Studio Otter 3 发布:日常开发选AS还是Cursor?
flutter·android studio·ai编程·跨平台开发·客户端开发
浩辉_9 小时前
Dart - 内存管理与垃圾回收(GC)深度解析
flutter·dart