• vue3中provide和inject的使用


    1.provide 和 inject 的讲解

    provide和inject可以实现嵌套组件之间进行传递数据。
    这两个函数都是在setup函数中使用的。
    父级组件使用provide向下进行传递数据;
    子级组件使用inject来获取上级组件传递过来的数据;
    需要注意的是:
    1==>provide只能够向下进行传递数据
    2==>在使用provide和inject的时候需从vue中引入
    

    2.provide 和 inject 的使用

    我们将创建2个组件
    儿子组件ErZi.vue
    孙子组件SunZI.vue
    我们将在父级组件中向其子代传递数据;
    那么儿子、孙子组件都将会接受到;
    并且在视图上显示出来
    

    3.父组件

    <template>
      <erzi-com></erzi-com>
    </template>
    <script lang="ts">
    import ErZi  from "../components/ErZi.vue"
    import {provide, ref} from "vue"
    export default {
      name:"About",
      components:{
        'erzi-com':ErZi
      },
      setup(){
        let giveSunziData=ref({
           with:100,
           height:50,
           bg:'pink'
        })
        // 第一个参数是是共享数据的名称(giveSunzi)
        // 第二个参数是共享的数据(giveSunziData)
        provide('giveSunzi',giveSunziData)
      }
    }
    </script>
    
    父组件向其子代组件传递了一个对象
    provide是在setUp这个组合APi中使用的
    provide的使用方式:
    provide('共享数据名称',共享值)
    共享值可以是字符串、数字、对象、数组
    
    子组件在进行接收到的时候;
    let xxx=inject('共享数据名称');
    

    4.儿子组件

    <template>
        <div>
          <h2>儿子组件</h2>
          <div>得到的值:{{getFaytherData}}</div>
        </div>
        <hr/>
        <sun-con></sun-con>
    </template>
    <script lang="ts">
    import { defineComponent, inject } from 'vue';
    import SunZI from "./SunZI.vue"
    export default defineComponent({
      name: 'ErZi',
       components:{
         'sun-con':SunZI
       },
        setup(){
          let getFaytherData=inject('giveSunzi');
          return { getFaytherData }
        }
    });
    </script>
    

    5.孙子组件

    <template>
        <div>
             <h2>孙子组件</h2>
             <div>得到的值{{getYeYeData}}</div>
        </div>
    </template>
    <script lang="ts">
    import { defineComponent,inject } from 'vue';
    export default defineComponent({
       setup(){
         let getYeYeData=inject('giveSunzi');
        return { getYeYeData }
       }
    });
    </script>
    

    6.效果图

    7.父组件可以传递多个rovide吗?

    有些时候,我们的父组件可能需要传递多个rovide;
    因为我们想让数据分开。
    此时就需要传递多个rovide。
    经过实践,父组件是可以传递多个rovide的!!!!
    这是没有没问题的;
    
    但是个人并不推荐这样处理
    我们可以在传递的时候将多个数据进行一次组装;
    组装好了之后再进行传递
    

    8.rovide和inject的引用场景

    当父组件有很多数据需要分发给其子代组件的时候,
    就可以使用provide和inject。
    
    作者:明月人倚楼
    出处:https://www.cnblogs.com/IwishIcould/

    想问问题,打赏了卑微的博主,求求你备注一下的扣扣或者微信;这样我好联系你;(っ•̀ω•́)っ✎⁾⁾!

    如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,或者关注博主,在此感谢!

    万水千山总是情,打赏5毛买辣条行不行,所以如果你心情还比较高兴,也是可以扫码打赏博主(っ•̀ω•́)っ✎⁾⁾!

    想问问题,打赏了卑微的博主,求求你备注一下的扣扣或者微信;这样我好联系你;(っ•̀ω•́)っ✎⁾⁾!

    支付宝
    微信
    本文版权归作者所有,欢迎转载,未经作者同意须保留此段声明,在文章页面明显位置给出原文连接
    如果文中有什么错误,欢迎指出。以免更多的人被误导。
  • 相关阅读:
    Boost.Asio c++ 网络编程翻译(10)
    建站手册:网站品质
    建站手册-template
    CDN:分类
    CDN:BootCDN 项目列表-摘录-20180405
    CDN:BootCDN
    CDN:目录
    CDN-template
    JavaScript-Tool:md5.js
    Regexp-Utils:基本
  • 原文地址:https://www.cnblogs.com/IwishIcould/p/14956337.html
Copyright © 2020-2023  润新知