Vue 自定义事件绑定与解绑

news2025/1/19 23:21:01

绑定自定义事件

说到 Vue 自定义事件,那就需要搞清楚一个问题,为啥有这个玩意。

说到自定义事件之前,需要理解 组件基础的概念。理解了基础概念之后,我们就知道 Vue 的父子之间的通信, 一是  父组件通过 Prop 向子组件传递数据 。二是 监听子组件事件。

具体详情参考之前的博文:Vue-父子组件传值。

vue-07-父子组件传值_vue handler(n) {}_白桃味稠鱼烧的博客-CSDN博客因为vue 的数据是单向流动的,这是为了避免数据污染。在官方文档中也说到:所有的 prop 都使得其父子 prop 之间形成了一个单向下行绑定:父级 prop 的更新会向下流动到子组件中,但是反过来则不行。这样会防止从子组件意外改变父级组件的状态,从而导致你的应用的数据流向难以理解。大致归纳一下:父传子--传值、子传父--传事件1、父传子如果传递的数据是对象格式的,那么在子组件 内部监..._vue handler(n) {}https://blog.csdn.net/qq_40792800/article/details/105559859这篇博文中详细说明了 父子组件传值的方法,其中就有 子组件传递数据给父组件的三种方法,其实就是 通过自定义事件 来实现的。实现方法也在其中详细说明了。

$off:解绑自定义事件

 上面说过了 通过绑定自定义事件,实现了子组件向父组件传递数据,那么既然有绑定方法,就应该和原生js一样,有解绑的方法,也存在解绑的方法,那就是 $off() 。

  • 如果没有提供参数,则移除所有的事件监听器;

  • 如果只提供了事件,则移除该事件所有的监听器;

  • 如果同时提供了事件与回调,则只移除这个回调的监听器

父组件只使用一种绑定方法

<School @test="test"/>

methods: {
  test(val) {
    console.log(val,'这是子组件传递过来的数据')
  },
},

子组件解绑事件

1、只提供事件,则移除该事件所有的监听器( 只传递一个事件和传递多个事件 )

<template>
  <div>
    <p class="demo" @click="goto">School组件</p>
    <p @click="unbind">解绑事件</p>
  </div>
</template>

export default {
  data() {
    return {
      msg: "子组件数据",
    };
  },
  methods: {
    goto() {
      this.$emit("test", this.msg);
    },
    unbind() {
      console.log("解绑事件");
      this.$off('test');  // 若只传递一个参数,则只解绑一个自定义事件
      this.$off(['test1','tset2','test3']);  // 若传递一个数组,则同时解绑传递的多个自定义事件
    },
  },
};

触发父组件事件之后,点击触发解绑事件,再次触发父组件事件,无法打印出子组件数据

 2、同时提供了事件与回调,则只移除这个回调的监听器

  • 我在子组件的 mounted 生命周期中 监听了 myEvent 事件,且该事件上存在两个回调函数
  • 点击 测试按钮时,$emit 触发 myEvent 事件,myEvent 事件上的回调函数全部触发
  • 点击解绑按钮,解绑 myEvent 事件 上的 this.myCallback() 函数,只剩下 匿名函数
  • 再次点击 测试按钮,发现 myEvent 事件 上,this.myCallback() 函数不触发,匿名函数触发
<template>
  <div>
    <p @click="test">测试</p>
    <p @click="remove">解绑myCallback</p>
  </div>
</template>

<script>
export default {
  mounted() {
    // 添加事件监听器,在组件挂载后执行 myCallback 函数
    this.$on('myEvent', this.myCallback);
    this.$on('myEvent', () => {
      console.log('我是匿名函数,我被触发了')
    });
  },
  methods: {
    test() {
      this.$emit('myEvent')
    },
    remove() {
      console.log('我解绑了myCallback,但是没有解绑匿名函数')
      this.$off('myEvent',this.myCallback)
    },
    myCallback() {
      console.log('我是myCallback,我被触发了')
    }
  },
};
</script>

 

 ps:$on 监听事件之后,需要 $emit 触发事件监听,才去执行 $off,不然绑定的事件没触发,看不出来效果( 绑定事件都不触发,你解绑它干啥,直接不监听就行了啵 )

3、 如果没有提供参数,则移除所有的事件监听器

在父组件中给 School子组件 绑定两个自定义事件

<School @test="test" @test1="test1"/>

methods: {
  test(val) {
    console.log(val,'这是子组件传递过来的数据')
  },
  test1(val) {
    console.log(val,'这是子组件传递过来的数据1')
  },
},

在子组件中触发两个绑定的自定义事件

<template>
  <div>
    <p @click="bind">绑定</p>
    <p @click="remove">解绑</p>
  </div>
</template>

<script>
export default {
  methods: {
    bind() {
      this.$emit('test','test')
      this.$emit('test1','test1')
    },
    remove() {
      this.$off()
    },
  },
};
</script>
  • 点击 bind 触发绑定事件,控制台上会打印出数据。
  • 点击 remove 移除所有绑定事件。
  • 再次点击 bind 触发绑定事件,控制台无输出,表明所有绑定事件已移除

 Vue destroyed() 生命周期

 实例销毁后调用。该钩子被调用后,对应 Vue 实例的所有指令都被解绑,所有的事件监听器被移除,所有的子实例也都被销毁。

<template>
  <div>
    <p @click="bind">绑定</p>
    <p @click="death">销毁子组件</p>
  </div>
</template>

<script>
export default {
  methods: {
    bind() {
      this.$emit('test','test')
      this.$emit('test1','test1')
    },
    death() {
      this.$destroy()
    }
  },
};
</script>
  • 点击 bind 按钮,触发绑定函数,控制台上输出。
  • 点击 销毁子组件 按钮,销毁子组件,移除所有事件监听器,解绑所有指令
  • 再次点击 bind 按钮,控制台无输出

总结

 1、组件的自定义事件是一种组件间的通信方式:子组件 向 父组件 传递数据

2、使用场景:子组件B 向 父组件A 传递数据,需要在 父组件A 中给 子组件B 绑定自定义事件( 事件的回调在 A 中 )

3、绑定自定义事件:

  • 第一种方式:在父组件中 
  • <School @test="test"/>
    
    <School v-on:test="test"/>
  • 第二种方式:在父组件中
  • <School ref='student'/>
    
    mounted() {
      this.$refs.student.$on('qwe', this.getname)
    }
  • 第三种方式:若想让自定义事件只能触发一次,可以使用 once 修饰符,或 $ones 方法

4、触发自定义事件 

this.$emit('test','向传递的数据')

 5、解绑自定义事件

this.$off()

6、也可以使用  生命周期钩子函数 this.$destroy() 来销毁组件达到解绑所有自定义事件

7、组件上也可以绑定 原生DOM事件,使用  .native 事件。即使是 @click 事件,Vue也不会将其解析为 自定义事件,不用在 School 子组件中 使用 $emit 触发

<School @click.native="test"/>

8 、注意:通过 this.$refs.xxx.$on( 'xxx' , callback ),绑定自定义事件时,callback 回调要么配置在 mtenods 中,要么使用箭头函数,否则 this 指向存在问题( 因为 callback 函数接收的参数都是从子组件中传递的,包括 this也是,如果使用 function () {} 函数,则该函数内部 this 指向子组件 )

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/828889.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CK_Label_V1 CK_Label_V9 CK_Label_V11 System Developer‘s Manual

一、Register PTL You should register the PTL to our Management System first&#xff1b; 1、Register CK_Label_V1 Quickly press the side button three times Register ok&#xff1a;The led will turn off after flashing red light and the buzzer will beep once…

一个3年Android的找工作记录

作者&#xff1a;Petterp 这是我最近 1个月 的找工作记录&#xff0c;希望这些经历对你会有所帮助。 有时机会就像一阵风&#xff0c;如果没有握住&#xff0c;那下一阵风什么时候吹来&#xff0c;往往是个运气问题。 写在开始 先说背景: 自考本&#xff0c;3年经验&#xff0…

【JVM】(二)深入理解Java类加载机制与双亲委派模型

文章目录 前言一、类加载过程1.1 加载&#xff08;Loading&#xff09;1.2 验证&#xff08;Verification&#xff09;1.3 准备&#xff08;Preparation&#xff09;1.4 解析&#xff08;Resolution&#xff09;1.5 初始化&#xff08;Initialization&#xff09; 二、双亲委派…

在线/开源GNSS处理软件/平台介绍

当前&#xff0c;存在较多的GNSS开源/免费软件&#xff0c;可用于质量检核、RTK解算和PPP解算等&#xff0c;本文总结了部分常用的处理软件&#xff0c;其详细信息如表1和表2所示。 表1 常用GNSS预处理&#xff08;格式转换、质量检核&#xff09;软件&#xff1a; 软件名称 …

RunnerGo五种压测模式你会配置吗

我们在做性能测试时需要根据性能需求配置不同的压测模式如&#xff1a;阶梯模式。使用jmeter时我们需要安装插件来配置测试模式&#xff0c;为了方便用户使用&#xff0c;RunnerGo内嵌了压测模式这一选项&#xff0c;今天给大家介绍一下RunnerGo的几种压测模式和怎么根据性能需…

基于各种方式划分 vlan

划分VLAN的方式有&#xff1a;基于接口、基于MAC地址、基于IP子网、基于协议、基于策略&#xff08;MAC地址、IP地址、接口&#xff09;。 VLAN&#xff08;虚拟局域网&#xff09;可以按照以下几种方式进行划分&#xff1a; 端口划分方式 将交换机端口按照需要划分成不同的…

低碳 Web 实践指南

现状和问题 2023年7月6日&#xff0c;世界迎来有记录以来最热的一天。气候变化是如今人类面临的最大健康威胁。据世界卫生组织预测2030年至2050年期间&#xff0c;气候变化预计每年将造成约25万人死亡。这是人们可以真切感受到的变化&#xff0c;而背后的主要推手是碳排放。 …

软件定时器

Q: 什么是定时器&#xff1f; A: 其实在单片机的学习中&#xff0c;已经接触过无数次定时器了&#xff0c;所谓定时器&#xff0c;简单可以理解为闹钟&#xff0c;到达指定一段时间后&#xff0c;就会响铃。 STM32 芯片自带硬件定时器&#xff0c;精度较高&#xff0c;达到定时…

一年级数学 数一数(一到十)

今天我们来学习数一数 有一些老人 眼睛可能花了 需要我们在动物园数清楚是多少个动物 然后告诉他们 可能有的小朋友 不知道某些数字怎么读 您可以打开地址 https://fanyi.baidu.com/?aldtype16047#zh/en/ 将数字 输入到 输入框内 然后点击 下面的小话筒 系统就会读出来了 小…

Java课题笔记~ MyBatis缓存

为了减少重复查询给数据库带来的压力&#xff0c;MyBatis提供了缓存机制&#xff0c;这种机制能够缓存查询的结果&#xff0c;避免重复的查询。 MyBatis提供了两种缓存方式&#xff1a; 一种为针对于SqlSession的缓存【默认开启】 另一种为针对于全局的缓存【手动开启】 一…

社科院与杜兰大学金融管理硕士为什么值得?来这里一探究竟

金融管理方向是近年来考研的热门专业&#xff0c;越来越多的学生在择校时也会将院校专业作为优先考虑的标准。而社科院与杜兰大学金融管理硕士项目作为热门中的热门&#xff0c;究竟为什么值得读呢&#xff1f;下面我们一起去探个究竟吧 一、中美名校强强联合&#xff0c;顶级师…

解压缩软件WinRAR-bandizip-7z--洛

个人收集的解压软件&#xff01;后期还会更新 ------------------------------------------------------------------- WinRAR&#xff1a;密码1234WinRARhttps://wwzb.lanzoue.com/b0485ldcj BandiZip&#xff1a;密码1234 Bandizip-Professionalhttps://wwzb.lanzoue.com/…

正交变换和仿射变换

正交变换和仿射变换 平面的正交变换 正交点变换&#xff08;保距变换&#xff09; 平面上的一个保持任意两点距离不变的点变换 平面正交变换性质 正交变换的乘积是正交变换恒等变换是正交变换正交变换将&#xff08;不&#xff09;共线的三点映射成&#xff08;不&#xff09…

微服务系列<3>---微服务的调用组件 rpc 远程调用

什么是rpc调用,让我们调用远程方法就像调用本地方法一样 这就属于rpc调用 rpc是针对于本地来说的 调用远程方法根调用本地方法一样 如果能达到这种效果 就是rpc调用如果达到一种效果 调用远程和调用本地一样 他就是一种rpc框架2个微服务 之间发的调用 我们之前通过ribbon的方式…

UG\NX 二次开发 相切面、相邻面的选择控件

文章作者&#xff1a;里海 来源网站&#xff1a;https://blog.csdn.net/WangPaiFeiXingYuan 简介&#xff1a; 有群友问“UFUN多选功能过滤面不能选择相切面或相邻面之类的吗&#xff1f;” 这个用Block UI的"面收集器"就可以&#xff0c;ufun函数是不行的。 效果&am…

python 将excel 多行进行分组合并

def exc():"""# 需要用到分组的概念:将角色和业务单据的进行分组,结果合并为一行"""df pd.read_excel(test33.xlsx)# 设置需要分组的字段cols [姓名, 科目]#agg() 其中的参数字段为之后输出的表格中的列字段df df.groupby(cols).agg({姓名: f…

Java三大特征之多态

文章目录 一、多态的概念二、多态实现条件三、重写四、向上转型和向下转型4.1向上转型4.2向下转型 五、多态的优缺点六、避免在构造方法中调用重写的方法 一、多态的概念 多态的概念&#xff1a;通俗来说&#xff0c;就是多种形态&#xff0c;具体点就是去完成某个行为&#x…

Error attempting to get column ‘xxx‘ from result set. Cause: java.sql.SQLDataException错误的解决方法

文章目录 1. 复现错误2. 分析错误3. 解决错误4. 文末总结 1. 复现错误 今天写好导入hive表的详情列表的接口&#xff0c;如下代码所示&#xff1a; /*** hive表导入的回调接口** author super先生* datetime 2023/3/20:16:32* return*/ResponseBodyGetMapping(value "/xx…

老师如何制作学生分班查询系统?

在新学期开始之前&#xff0c;学校和教师需要确定学生的分班信息&#xff0c;以便学生在返校前做好准备。在这个过程中&#xff0c;一个功能强大的分班查询系统将非常有用&#xff0c;可以帮助家长和学生快速查看分班情况。制作一个分班查询系统需要仔细规划和设计&#xff0c;…

ORB-SLAM2栅格地图构建

过程 栅格地图的构建是基于稠密点云地图的构建和保存实现的&#xff0c;需要了解可以看我们前面的博客 基于ORB-SLAM2实时构建稠密点云 在点云地图的基础上构建包含占据信息的八叉树地图和二维栅格地图&#xff0c;便于后续避障、导航等功能的实现 点云转八叉树可以参考下面的…