我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue中怎么使用addEventListener添加事件和removeEventListener移除事件

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue中怎么使用addEventListener添加事件和removeEventListener移除事件

今天小编给大家分享一下Vue中怎么使用addEventListener添加事件和removeEventListener移除事件的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

在vue中如何使用addEventListener添加事件、removeEventListener移除事件

最近在项目中需要用到addEventListener监听滚动条滚动的高度,所以就研究了一下在vue中是怎么进行事件监听的。

添加事件

给要添加事件的元素加上ref属性

Vue中怎么使用addEventListener添加事件和removeEventListener移除事件

在mounted中添加事件

    mounted() {      this.$refs.box.addEventListener('scroll',()=>{        console.log('scroll',this.$refs.box.scrollTop)      });    }

这样就添加成功了!

Vue中怎么使用addEventListener添加事件和removeEventListener移除事件

移除事件

如果要移除已添加的事件,removeEventListener中传入的方法必须和addEventListener中传入的是同一个方法才能成功移除,所以在添加时就不能用匿名函数啦。需改成如下写法

    mounted() {      this.$refs.box.addEventListener('scroll',this.scrollEvent);    },    methods:{      scrollEvent(){        console.log('scroll',this.$refs.box.scrollTop)      }    }

这里要注意 传入的方法 this.scrollEvent 后面不能加括号,否则无法成功添加

组件销毁前移除事件

    beforeDestroy() {      this.$refs.box.removeEventListener('scroll',this.scrollEvent);    }

如果是keep-alive组件,可以用下面这种方式

  activated() {    this.$refs.box.addEventListener('scroll', this.scrollEvent);  },  deactivated(){    this.$refs.box.removeEventListener('scroll',this.scrollEvent);  },

另外,addEventListener还可以给一个元素添加多个事件,并且不会覆盖已存在的事件,这里就不多展开了~

扩展知识:

解析Vuejs使用addEventListener的事件触发执行函数的this问题

1、使用浏览器监听切屏为例

此处为考虑浏览器兼容性推荐使用:document.addEventListener

1.1、正常函数使用如下:

let n = 0;let max = 3; //   切屏最大次数document.addEventListener("visibilitychange", function () {    if(document.visibilityState == 'hidden'){        n++;    } else if(document.visibilityState == 'visible') {        if (n > max) {            this.$alert('你已经切换离开考试页面超过'+max+"次系统将自动提交答卷!", '警告', {                confirmButtonText: '知道了',                callback: action => {                    this.msgSuccess("系统自动提交答卷!");                }            });            return;        }        this.$alert('你已经切换离开考试页面'+n+'次,如果超过'+max+"次系统会自动提交答卷,请认真作答!", '警告', {            confirmButtonText: '知道了',            callback: action => {}        });    }});

this.$alert()为vue的MessageBox弹框组件

运行后报:

Vue中怎么使用addEventListener添加事件和removeEventListener移除事件

提示this.$alert()不是一个函数

此时我们尝试在document函数里面打印this到控制台看看

console.log("this===",this);

控制台输出信息:

Vue中怎么使用addEventListener添加事件和removeEventListener移除事件

指向的是调用addEventListener的对象

我们使用document对象去调用VueJS的组件函数肯定是行不通的,那么怎样可以拿到VueJS的this呢?我们只需稍作修改

1.2、bind()绑定事件指定函数

修改后的代码如下:

let n = 0;let max = 3; //   切屏最大次数let fn = function () {    console.log("this===",this);    if(document.visibilityState == 'hidden'){        n++;    } else if(document.visibilityState == 'visible') {        if (n > max) {            this.$alert('你已经切换离开考试页面超过'+max+"次系统将自动提交答卷!", '警告', {                confirmButtonText: '知道了',                callback: action => {                    this.msgSuccess("系统自动提交答卷!");                }            });            return;        }        this.$alert('你已经切换离开考试页面'+n+'次,如果超过'+max+"次系统会自动提交答卷,请认真作答!", '警告', {            confirmButtonText: '知道了',            callback: action => {}        });    }}// 使用bind绑定的事件才是指向函数,否则指向的是调用addEventListener的对象document.addEventListener("visibilitychange", fn.bind(this));

详解:

将触发事件后执行的函数抽到外部,作为外部函数并赋予函数名在事件中使用函数名.bind('指定函数');即可在执行的函数中获取到bind绑定的指定函数

控制台查看此时的this为

Vue中怎么使用addEventListener添加事件和removeEventListener移除事件

效果图:

Vue中怎么使用addEventListener添加事件和removeEventListener移除事件

下面介绍下vue 监听事件addEventListener

代码如下所示:

// vue 添加监听事件,addEventListener第二个参数要绑在this上,即需要在methods中声明,否则销毁的时候会报错// 在mounted中监听,在beforeDestroy中销毁,绑定的事件在methods中声明mounted() {    // 监听    window.addEventListener('resize', this.handleEventListener)  },beforeDestroy() {  // 销毁  window.removeEventListener('resize', this.handleEventListener)},methods: {  // 监听执行的事件  handleEventListener() {      },}

以上就是“Vue中怎么使用addEventListener添加事件和removeEventListener移除事件”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue中怎么使用addEventListener添加事件和removeEventListener移除事件

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue中怎么使用addEventListener添加事件和removeEventListener移除事件

今天小编给大家分享一下Vue中怎么使用addEventListener添加事件和removeEventListener移除事件的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读
2023-07-04

vue怎么添加和移除事件

vue添加和移除事件的方法:1、通过“addEventListener()”方法添加事件句柄;2、通过“removeEventListener()”方法移除事件句柄。
2023-05-14

vue如何添加和移除事件

这篇文章主要介绍“vue如何添加和移除事件”,在日常操作中,相信很多人在vue如何添加和移除事件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue如何添加和移除事件”的疑惑有所帮助!接下来,请跟着小编一起来
2023-07-04

Vue的addEventListener()监听事件怎么使用

本篇内容介绍了“Vue的addEventListener()监听事件怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、语法eleme
2023-07-04

vue自定义组件怎么添加使用原生事件

今天小编给大家分享一下vue自定义组件怎么添加使用原生事件的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。自定义组件如何添加使
2023-06-30

怎么用ADO.NET RowUpdated添加删除事件处理程序

这篇文章主要讲解了“怎么用ADO.NET RowUpdated添加删除事件处理程序”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用ADO.NET RowUpdated添加删除事件处理程序
2023-06-17

Vue组件的自定义事件和全局事件总线怎么使用

这篇“Vue组件的自定义事件和全局事件总线怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue组件的自定义事件和全局
2023-07-05

使用Unity怎么给物体动态添加事件

这篇文章给大家介绍使用Unity怎么给物体动态添加事件,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。using System.Events;using System.EventSystems;//_go is the
2023-06-14

Vue中的@blur/@focus事件怎么使用

这篇文章主要讲解了“Vue中的@blur/@focus事件怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue中的@blur/@focus事件怎么使用”吧!Vue的@blur/@fo
2023-07-05

vue动态添加元素点击事件不起作用怎么办

在Vue中,很多时候我们需要动态地添加元素到页面上。然而,有时候我们会发现这些动态添加的元素的点击事件不起作用,这是为什么呢?本文将为您介绍原因及解决方法。一、原因我们首先来了解一下为什么动态添加的元素的点击事件不起作用。这是因为Vue在页面加载过程中会对已存在的元素进行监听,当点击事件发生时,会触发Vue实例上的对应方法。但是,当我们动态添加元素时,Vue并不会自动为这些元素
2023-05-14

JavaScript中BOM,DOM和事件怎么使用

这篇文章主要介绍“JavaScript中BOM,DOM和事件怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript中BOM,DOM和事件怎么使用”文章能帮助大家解决问题。BOM概
2023-07-02

C#中怎么使用委托和事件

在 C# 中,委托和事件是一种常用的机制,用于实现事件驱动的编程模型。委托是一种类型,用于存储对方法的引用,而事件是委托的一种特殊用法,用于通知其他代码发生了某个特定的动作。下面是一个简单的示例,演示了如何在 C# 中定义和使用委托和事件
C#中怎么使用委托和事件
2024-03-06

vue开发移动端使用better-scroll时click事件失效怎么办

本篇内容介绍了“vue开发移动端使用better-scroll时click事件失效怎么办”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在引入
2023-07-04

WPF中的附加事件是什么及怎么使用

今天小编给大家分享一下WPF中的附加事件是什么及怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。什么是附加事件Micr
2023-07-04

vue事件修饰符和按键修饰符怎么使用

本篇内容主要讲解“vue事件修饰符和按键修饰符怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue事件修饰符和按键修饰符怎么使用”吧!在事件处理程序中调用 event.preventDe
2023-07-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录