vue中的侦听器和组件之间的通信

目录

一、侦听器

监听基本数据类型:

监听引用数据类型:

计算属性和watch区别?

二、组件通信/传值方式

1.父子组件传值

    父组件给子组件传值:

      (1)props

      (2)provide inject

      (3)事件总线 $emit 和 $on vue实例调用方法 

    子组件给父组件传值:

    (1)事件总线 $emit 和 $on vue实例调用方法 

  2.兄弟组件传值/通信

    (1)利用事件总线 

    (2)vuex  

  3.祖先后代组件传值/通信

      (1)provide inject


一、侦听器

只有监听数据发生改变才会触发侦听器 

监听基本数据类型:

通过下面这个小案例来学习,通过监听a和b的值,来实现计算求和的功能

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2.7.14/dist/vue.js"></script>
</head>
<body>
    <div id="app">
        <!-- number修饰符 可以让双向数据绑定的值变为number类型 -->
        a:<input type="text" v-model.number="a">
        <br>
        +
        <br>
        b:<input type="text" v-model.number="b">
        <br>
        =
        <br>
        <output>
            {{total}}
        </output>
    </div>
    <script>
        let vm = new Vue({
            // 与模板绑定
            el:"#app",
            // 数据模型 存放vue变量
            data:{
                a:0,
                b:0,
                total:0,
                name:"",
                obj:{

                }
            },
            // 存放方法和事件处理程序
            methods: {
                
            },
            computed:{
                // total(){
                //     return Number(this.a) + Number(this.b)
                // }
            },
            // 侦听器 监听器  什么时候触发? 只有数据发生变化才会触发
            watch:{
                a(newValue,oldValue){
                    // console.log(newValue,oldValue);
                    this.total = newValue + this.b
                },
                b(newValue,oldValue){
                    // console.log(newValue,oldValue);
                    this.total = this.a + newValue
                }
            }
        });
        
    </script>
</body>
</html>

浏览器运行结果如下:

 


监听引用数据类型:

当侦听器在监听引用数据类型时存在监听不到的问题,这时我们就需要开启深度监听

params:{
      handler(n,o){
        this.getArticle();
      },
      //开启深度监听
      deep:true
    }
  }

计算属性和watch区别?

  1.计算属性有缓存性,响应式依赖不发生改变,多次调用计算属性会返回之前得计算结果。
  2.watch无缓存性,只有数据发生改变侦听器才会执行。
  3.watch侦听器一般用于异步操作或者开销较大得操作。
  4.计算属性默认可读,设置setter就可修改。

二、组件通信/传值方式

1.父子组件传值
    父组件给子组件传值:
      (1)props

      1.在子组件标签中写入父组件传递数据 向下传递prop
      2.在子组件内声明props选项接收父组件传递的数据 props:['','','']

    <!-- 动态传递 传递的变量 使用v-bind绑定 -->
    <Header :msg="msg"></Header>
    <!-- 静态传递 -->
    <Header title="我是父组件中title"></Header>
    <!-- 3.传递其他数据类型 除字符串外 传递数组对象number布尔值 动态传参 -->
    <Header :arr="[1,2,3,4]" :obj="{name:'zhangsan'}" :bool="true" :age="20"></Header>
    // 子组件使用props接收父组件传递的数据
    props:['msg'],
    props:['title'],
    props: ['msg', 'age', 'bool', 'arr', 'obj'],

      (2)provide inject

      1.父组件使用provide提供传递数据或者方法(与methods同级)
      2.子组件使用inject注入传递的数据或者方法

  // 注入传递给后代组件的数据或者方法
  provide(){
    return{
      parent:this.parent,
      parentSend:this.parentSend,
      attr:this.attr
    }
  }
}
    // 使用provide传递的数据方法使用inject注入  后代组件注入祖先组件传递数据和方法
    inject: ['parent', 'parentSend'],

      (3)事件总线 $emit 和 $on vue实例调用方法 

      1.新建event.js 
        import Vue from 'vue';
        export default new Vue();

// 定义事件总线 导出vue实例对象
import Vue from "vue";
export default new Vue();


      2.在父组件中使用$emit发射自定义事件同时传递参数
      import Bus from './event.js'
      Bus.$emit('自定义事件名称',传递数据)

    <!-- 3.第三种传值方式 -->
    <button @click="handler">发射数据给header子组件</button>
    handler(){
      // $emit() 发射自定义事件 参数(自定义事件名称 传递的参数)
      Bus.$emit('toHeader',this.pMsg,'hello world')
    },


      3.在子组件内部使用$on监听自定义事件同时接收参数
      Bus.$on('自定义事件名称',(a,b)=>{

      })

        // $on监听$emit自定义事件 参数(自定义事件名称,()=>{})
        Bus.$on('toHeader', (a, b) => {
            console.log(a, b);
            this.a = a;
            this.b = b;
        })

    子组件给父组件传值:
    (1)事件总线 $emit 和 $on vue实例调用方法 

      1.发射自定义事件给父组件同时传递数据
      this.$emit('toParent',this.footer);
      2.在父组件模板中(在子组件标签上)声明自定义事件 
      <Footer @toParent='事件处理程序'></Footer>
      事件处理程序(接收子组件传递的数据){

      }

        和父给子传的第三种方式一样

  2.兄弟组件传值/通信
    (1)利用事件总线 

    1.定义事件总线 新建xxx.js
        import Vue from 'vue';
        export default new Vue();
    2.在一个兄弟组件中引入事件总线 
      import Bus from './event.js'
      使用Bus.$emit('自定义事件名称',传递的数据)
    3.在另一个兄弟组件中引入事件总线
      import Bus from './event.js'
      使用Bus.$on('emit发射自定义事件名称',(a,b)=>{
        
      })监听发射自定义事件 同时接收数据

        同父给子传的第三种方式


    (2)vuex  

        关于vuex后续文章会详细说明,父子组件、兄弟组件、无关系组件任意组件之间的传值。

        Vuex本质上也是一种本地存储,比localStorage的单纯值传递多了方法、属性、异步方法等功能。但是因为是将内容本地化,所以就会被在浏览器中获取到。

  3.祖先后代组件传值/通信
      (1)provide inject

        同父给子传的第二种方式

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

k8s中Helm工具实践

k8s中Helm工具实践 1&#xff09;安装redis-cluster 先搭建一个NFS的SC&#xff08;只需要SC&#xff0c;不需要pvc&#xff09;&#xff0c;具体步骤此文档不再提供&#xff0c;请参考前面相关章节。 下载redis-cluster的chart包 helm pull bitnami/redis-cluster --untar…

Java可变参数(学习推荐版,通俗易懂)

定义 可变参数本质还是一个数组 示例代码 注意事项 1.形参列表中&#xff0c;可变参数只能有一个 2.可变参数必须放在形参列表的最后面 注意是最后面。 name也可以为int类型

做题总结 202. 快乐数

202. 快乐数 思路分析代码实现-Java代码优化 思路分析 本人没有思路 在看题的时候&#xff0c;我不知道如果 不是快乐数怎么处理。我感觉是会死循环&#xff0c;一直加下去。没有考虑到会有重复数字出现。 为什么不会进行死循环&#xff1f;&#xff08;为什么会有重复数字出…

DevOps系列文章 : 使用dpkg命令打deb包

创建一个打包的目录&#xff0c;类似rpmbuild&#xff0c;这里创建了目录deb_build mkdir deb_build目标 我有一个hello的二进制文件hello和源码hello.c, 准备安装到/opt/helloworld目录中 步骤 在deb_build目录创建一个文件夹用于存放我的安装文件 mkdir helloworld在he…

SAP 特殊采购类30简介---标准委外

前面我们已经测试了很多的特殊采购类,今天我们测试一个在SAP系统中非常基本的功能—采购外协,通常采购外协和工序外协经常会被放在一起讨论方案,同时每个PP模块顾问和MM模块顾问所必需的。这个功能技术上讲不是很难,需要理解这个外协的意思。采购外协有时也会被称为标准外协…

[MySQL]用基本的mysql语句写的{商店的数据}和{学生成绩}

文章目录 前言一、题目二、创建2.写入table 三.查看表单结构四.插入数据1.俩种方法2.指定插入 五.查询1.全部和指定查询2.别名查询3.去重4.排序5.条件查询&#xff08;where) 六.修改七.删除八.在table中插入一列总结&#xff1a; 前言 提示&#xff1a;以下是本篇文章正文内容…

Temporary failure in name resolution

报错&#xff1a; 1.打开resolv.conf文件 sudo vim /etc/resolv.conf 2. 确保resolv.conf文件至少包含一个名称服务器。列出名称服务器的行应如下所示&#xff1a; 3. 保存文件并退出。 4. 接下来&#xff0c;重新启动DNS 解析器服务。运行以下命令&#xff1a; sudo syste…

探索未来交通!空客、宝马开启新一轮“量子计算挑战赛”

12月6日&#xff0c;空中客车公司和宝马集团共同发起了一项名为 “量子交通探索”的全球量子计算挑战赛&#xff0c;以应对航空和汽车领域最紧迫的挑战——这些挑战对于传统计算机而言仍然是难以克服的。 这项挑战是首创性的&#xff0c;它将两个全球行业领导者聚集在一起&…

Pytest+Requests+Allure实现接口自动化测试

一、整体结构 框架组成&#xff1a;pytestrequestsallure设计模式&#xff1a; 关键字驱动项目结构&#xff1a; 工具层&#xff1a;api_keyword/参数层&#xff1a;params/用例层&#xff1a;case/数据驱动&#xff1a;data_driver/数据层&#xff1a;data/逻辑层&#xff1a…

windows VMWare 安装虚拟机-保姆级教程,涵盖网络配置

1、虚拟机是什么 虚拟机&#xff08;Virtual Machine&#xff0c;简称 VM&#xff09;是一种运行在物理计算机上的软件实体&#xff0c;它模拟了一台完整的计算机系统。虚拟机可以在一台物理计算机上同时运行多个操作系统和应用程序&#xff0c;每个虚拟机都被分配了独立的计算…

C#攻克反爬虫之代理IP爬取

目录 前言 一、什么是代理IP 二、代理IP的获取 1. 免费代理IP网站 2. 第三方API 三、C#实现代理IP爬取 1. 安装HtmlAgilityPack和HttpClient 2. 获取代理IP 3. 使用代理IP发送请求 四、常见问题及解决方案 1. 代理IP的可用性 2. 频繁更换代理IP 总结 前言 随着互…

坚持提升这个能力,让你越来越强大

哈喽&#xff0c;你好啊&#xff01;我是雷工。 今天在读《张一鸣管理日志》时&#xff0c;看到这么一句话&#xff1a; “产品创新要从根本上解决问题&#xff0c;而不是想办法绕过问题&#xff0c;解决的问题很可能就是将来的核心竞争力。” 这让我想起了亚马逊公司&#x…

还在用QQ拼音输入法吗?赶快卸载吧~!

最近总觉得我的C盘在莫名其妙的减少。之前的电脑C盘只有240G&#xff0c;所以我很在意C盘空间。但是&#xff0c;我发现买了新电脑&#xff0c;C盘空间也在莫名其妙减少。 随挨个文件夹检查。最后发现&#xff0c;QQ拼音的 dict 文件夹很大&#xff0c;居然有 30G多G。 30多~…

图片曝光修正方法(直方图均衡和CNN)

图像过曝或曝光不足时需要曝光处理&#xff0c; 这里以曝光不足举例。 直方图均衡法&#xff1a; 通过RGB通道的直方图均衡达到处理曝光不足的效果。 代码&#xff1a; underexpose cv2.imread("exposure_test.jpg") #underexpose cv2.cvtColor(underexpose, cv2…

leetcode 1314. 矩阵区域和(优质解法)

代码&#xff1a; class Solution {public int[][] matrixBlockSum(int[][] mat, int k) {int mmat.length;int nmat[0].length;int[][]answernew int[m][n]; //要返回的结果矩阵int[][]sumnew int[m1][n1]; //前缀和数组//初始化前缀和数组for(int i1;i<m;i){for(int…

Java泛型-13

泛型的好处 public class Demo01 {public static void main(String[] args) {Person<String> person new Person<String>("韩曙平");} }class Person<E>{ //创建时才定义数据类型 编译时就可以进行约束E str;public Person(E str){this.str str…

Github项目推荐:在线rename

项目地址 GitHub - JasonGrass/rename: 在线文件批量重命名 项目简介 一个开源的在线重命名文件工具。利用了新的浏览器API获取文件句柄&#xff0c;在不上传文件的情况下对文件进行重命名。可以作为前端文件操作api学习范例。 项目截图

PropTypes 在 React 中的使用心得

在 React 开发中&#xff0c;PropTypes 是一个非常有用的库&#xff0c;用于对组件的属性进行类型检查。它可以帮助我们在开发过程中捕获潜在的错误&#xff0c;提高代码的可靠性和可维护性。本文将介绍 PropTypes 的基本用法和一些使用心得。 一、什么是 PropTypes PropTypes…

Android 权限申请

在Android中&#xff0c;从Android 6.0&#xff08;API级别23&#xff09;开始&#xff0c;应用在运行时需要动态申请权限。以下是一些步骤来动态申请权限&#xff1a; 在应用的清单文件&#xff08;AndroidManifest.xml&#xff09;中声明需要的权限。例如&#xff0c;如果应…