Vue3入门指北(七)事件处理

简介: Vue3入门指北(七)事件处理

前言


当我们需要监听页面的DOM事件的时候,我们可以使用vue提供的v-on指令来进行监听,当然也可以使用简写形式@,然后出入相应的JavaScript代码。


事件处理


事件处理器的值分为两类:


  • 内联事件处理器:事件被触发时执行的内联 JavaScript 语句。
  • 方法事件处理器:一个指向组件上定义的方法的属性名或是路径。


内联事件处理器


内联事件处理器常用于一些业务场景逻辑简单的地方。例如:


const num = ref(0)
复制代码


<button @click="num++">Add 1</button>
<p>数值: {{ num }}</p>
复制代码


方法事件处理器


当业务场景复杂的时候,内联的方式无法清晰简明的解决问题的时候。就可以通过使用方法事件处理器的形式,只需要传递一个 方法名,就会完成对该方法的调用。


const num = ref('0')
function add(event) {
  // `event` 是 DOM 原生事件
  if (event) {
    console.log(event.target.tagName)
  }
}
复制代码


<button @click="add">数值:{{num}}</button>
复制代码


方法事件处理器接受的第一个参数为DOM的原生事件。通过event.target.tagName可以访问到该元素


vue会通过检查v-on的值来判断是何种事件处理器。而像直接传递方法的,例如:add就是方法事件处理器。像add()num++这种形式的就会判为内联事件处理器。


在内联事件处理器中访问事件参数


当我们使用内联处理器的时候也想访问原生DOM事件的时候,可以通过$event变量的形式,或者箭头函数的形式来实现。


<!-- 使用 $event 变量 -->
<button @click="add('0', $event)">
  Submit
</button>
<!-- 使用箭头函数 -->
<button @click="(event) => add('0', event)">
  Submit
</button>
复制代码


function add(value, event) {
  if (event) {
    event.preventDefault()
  }
  console.log(value)
}


相关文章
|
8天前
|
JavaScript
Vue3中路由跳转的语法
Vue3中路由跳转的语法
111 58
|
1天前
|
存储 API
vue3中如何动态自定义创建组件并挂载
vue3中如何动态自定义创建组件并挂载
|
7天前
|
JavaScript 索引
Vue 2和Vue 3的区别以及实现原理
Vue 2 的响应式系统通过Object.defineProperty来实现,它为对象的每个属性添加 getter 和 setter,以便追踪依赖并响应数据变化。
22 9
|
8天前
|
JavaScript 开发工具
vite如何打包vue3插件为JSSDK
【9月更文挑战第10天】以下是使用 Vite 打包 Vue 3 插件为 JS SDK 的步骤:首先通过 `npm init vite-plugin-sdk --template vue` 创建 Vue 3 项目并进入项目目录 `cd vite-plugin-sdk`。接着,在 `src` 目录下创建插件文件(如 `myPlugin.js`),并在 `main.js` 中引入和使用该插件。然后,修改 `vite.config.js` 文件以配置打包选项。最后,运行 `npm run build` 进行打包,生成的 `my-plugin-sdk.js` 即为 JS SDK,可在其他项目中引入使用。
|
7天前
|
JavaScript
vue学习(10)事件修饰符
vue学习(10)事件修饰符
25 3
|
6天前
|
JavaScript 调度
Vue3 使用 Event Bus
Vue3 使用 Event Bus
11 1
|
7天前
|
JavaScript
Vue3 : ref 与 reactive
Vue3 : ref 与 reactive
9 1
vue3 reactive数据更新,视图不更新问题
vue3 reactive数据更新,视图不更新问题
|
7天前
|
JavaScript
|
7天前
vue3定义暴露一些常量
vue3定义暴露一些常量