首页 web前端 Vue.js 详解vue.js中如何处理事件

详解vue.js中如何处理事件

Oct 27, 2020 pm 05:52 PM
vue.js 处理事件

下面vue.js教程给大家介绍一下使用vue.js处理事件的方法,希望对大家有一定的帮助。

详解vue.js中如何处理事件

当您使用Vue构建动态网站时,您很可能希望它能够响应事件。

例如,如果用户单击按钮,提交表单,甚至只是移动鼠标,您可能希望您的Vue网站以某种方式做出响应。

使用Vue处理事件

我们可以通过将v-on指令添加到相关DOM元素来拦截事件。假设我们要处理对按钮元素的点击-我们可以在Vue模板中添加以下内容:

<button v-on:click="clickHandler"></button>
登录后复制

请注意,我们在指令中添加了一个参数,该v-on参数将是我们要处理的事件的名称(在本例中为click)。

然后,我们将表达式绑定到指令,该指令通常是您要用于处理事件的方法。在这种情况下,我们称之为clickHandler

提示:该v-on指令具有一个方便的速记形式@,可以代替以下形式使用v-on::<button @click="clickHandler"></button>

可以处理的事件类型

除了click之外,还可以处理哪些DOM事件?

Vue可以处理任何类型的web或移动本机事件(以及我们稍后将讨论的自定义事件),包括:

  • submit

  • keyup

  • drag

  • scroll

最常见的DOM事件的列表

事件处理方法

如果将方法绑定到事件处理指令,我们现在可以运行一些自定义代码。

在本示例中,让我们保持简单,只将一条消息记录到控制台,但是您还可以做一些更有趣的事情,例如显示/隐藏另一个元素,增加计数器等。

<div id="app">
  <button v-on:click="clickHanlder"></button>
</div>
登录后复制
new Vue({
  el: "#app",
  methods: {
    clickHandler () {
      console.log("You clicked the button!");
    }
  }
})
登录后复制

事件对象

事件对象将传递给事件处理程序,从而为如何响应事件打开了更多的可能性。这个对象包含很多有用的属性和方法,包括对事件起源的元素(event.target)、事件发生的时间(event.timeStamp)等的引用。

clickHandler (event) {
  console.log(`The button was clicked at ${event.timeStamp}.`);
}
登录后复制

请注意,此对象是由本机Web API提供的,而不是由Vue提供的,因此它将与您在纯JavaScript中找到的对象相同。为了方便起见,以下是事件接口参考

事件修饰符

JavaScript应用程序中的一种常见模式是手动处理表单提交,而不是使用本机功能。为此,您需要preventDefault在运行表单处理代码之前使用Submit事件的本机方法,否则页面将在有机会完成之前被重定向。

formHandler (event) {
  event.preventDefault();
  // form handling logic
}
登录后复制

Vue提供了一个事件修饰符来直接从模板执行此操作,而不是在处理程序中手动执行此操作。请注意,修饰符是'.'在指令之后添加的:

<form @submit.prevent="formHandler"></form>
登录后复制

Vue提供了几种不同的事件修饰符,这些修饰符在常见事件处理场景中非常有用:

  • .stop

  • .prevent

  • .capture

  • .self

  • .once

  • .passive

自定义事件

到目前为止,我们一直在讨论如何处理本机事件。但是Vue是一个基于组件的框架,所以我们可以让组件发出它自己的事件吗?

是的,这可能非常有用。 假设希望子组件将数据发送到父组件。 我们无法在此处使用道具,因为道具数据仅在父级到子级之间传递,而在其他方面则不行。

ParentComponent
 |
 | (data travels down via props, never up)  
 v 
ChildComponent
登录后复制

解决方案是让子组件发出事件,并让父组件监听该事件。

为此,请this.$emit("my-event")在希望事件发出时从子组件中调用。例如,假设我们有一个组件DialogComponent,它需要通知其父MainPage它已关闭:

export default {
  methods: {
    onClose() {
      this.$emit("dialog-closed");
    }
  }
};
登录后复制

然后,父组件可以与本地事件完全一样地处理自定义事件。

<div>
  <dialog-component @dialog-closed="eventHandler" />
</div>
登录后复制

您还可以在自定义事件中发送数据,该数据可以通过处理方法接收:

onClose() {
  this.$emit("dialog-closed", { time: Date.now() });
}
登录后复制
eventHandler (event, { time }) {
  console.log(`Dialog was closed at ${time}`);
}
登录后复制

提示:使用kebab-case名称进行自定义事件!HTML不区分大小写,因此,例如myEvent,驼峰事件名称将令人迷惑地myevent位于模板中。因此,最好使用kebab-case my-event,以免造成混淆。

活动巴士

如上所述,子组件可以将事件发送到父组件。但是,如果您希望组件将事件发送到层次结构中的任何其他组件怎么办?例如,同级,祖父母等。

为此,我们可以使用一种称为事件总线的模式。在这里,我们创建了一个单独的Vue实例,以将事件传输到导入该事件的任何组件。

首先,在新的模块文件中创建并导出Vue实例:

import Vue from "vue";
export default new Vue();
登录后复制

接下来,将总线导入到您要发出事件的组件中。您可以使用$emit总线Vue实例的方法。

import eventBus from "./eventBus";

export default {
  ...
  methods: {
    myMethod () {
      eventBus.$emit("my-event")
    }
  }
}
登录后复制

最后,将总线导入到您想听事件的组件中。然后,您应该在代码中的某个位置设置侦听器。我建议您使用生命周期挂钩,就像created您可以在此处访问组件实例一样。

这是通过$on总线方法完成的,该方法带有两个参数-您要监听的事件和一个回调。

import eventBus from "./eventBus";

export default {
  ...
  created () {
    eventBus.$on("my-event", () => {
      console.log("my-event called on global event bus");
    });
  }
}
登录后复制

相关推荐:

2020年前端vue面试题大汇总(附答案)

vue教程推荐:2020最新的5个vue.js视频教程精选

更多编程相关知识,请访问:编程入门!!

以上是详解vue.js中如何处理事件的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

深入探讨vite是怎么解析.env文件的 深入探讨vite是怎么解析.env文件的 Jan 24, 2023 am 05:30 AM

使用vue框架开发前端项目时,我们部署的时候都会部署多套环境,往往开发、测试以及线上环境调用的接口域名都是不一样的。如何能做到区分呢?那就是使用环境变量和模式。

vue中组件化和模块化有什么区别 vue中组件化和模块化有什么区别 Dec 15, 2022 pm 12:54 PM

组件化和模块化的区别:模块化是从代码逻辑的角度进行划分的;方便代码分层开发,保证每个每个功能模块的职能一致。组件化是从UI界面的角度进行规划;前端的组件化,方便UI组件的重用。

图文详解如何在Vue项目中集成Ace代码编辑器 图文详解如何在Vue项目中集成Ace代码编辑器 Apr 24, 2023 am 10:52 AM

Ace 是一个用 JavaScript 编写的可嵌入代码编辑器。它与 Sublime、Vim 和 TextMate 等原生编辑器的功能和性能相匹配。它可以很容易地嵌入到任何网页和 JavaScript 应用程序中。Ace 被维护为Cloud9 IDE的主要编辑器 ,并且是 Mozilla Skywriter (Bespin) 项目的继承者。

深入聊聊vue3中的reactive() 深入聊聊vue3中的reactive() Jan 06, 2023 pm 09:21 PM

前言:在vue3的开发中,reactive是提供实现响应式数据的方法。日常开发这个是使用频率很高的api。这篇文章笔者就来探索其内部运行机制。

探讨如何在Vue3中编写单元测试 探讨如何在Vue3中编写单元测试 Apr 25, 2023 pm 07:41 PM

当今前端开发中,Vue.js 已经成为了一个非常流行的框架。随着 Vue.js 的不断发展,单元测试变得越来越重要。今天,我们将探讨如何在 Vue.js 3 中编写单元测试,并提供一些最佳实践和常见的问题及解决方案。

浅析Vue3动态组件怎么进行异常处理 浅析Vue3动态组件怎么进行异常处理 Dec 02, 2022 pm 09:11 PM

Vue3动态组件怎么进行异常处理?下面本篇文章带大家聊聊Vue3 动态组件异常处理的方法,希望对大家有所帮助!

Vue中JSX语法和模板语法的简单对比(优劣势分析) Vue中JSX语法和模板语法的简单对比(优劣势分析) Mar 23, 2023 pm 07:53 PM

在Vue.js中,开发人员可以使用两种不同的语法来创建用户界面:JSX语法和模板语法。这两种语法各有优劣,下面就来探讨一下它们的区别和优劣势。

浅析vue怎么实现文件切片上传 浅析vue怎么实现文件切片上传 Mar 24, 2023 pm 07:40 PM

在实际开发项目过程中有时候需要上传比较大的文件,然后呢,上传的时候相对来说就会慢一些,so,后台可能会要求前端进行文件切片上传,很简单哈,就是把比如说1个G的文件流切割成若干个小的文件流,然后分别请求接口传递这个小的文件流。

See all articles