vue3 非父子组件通信详解

2022-04-15 0 578
目录
  • 第一种方法
    • App.vue
    • Home.vue
    • HomeContent.vue
    • 数据的响应式
    • 修改响应式Property
  • 总结

    业务场景是,不是父子组件实现通信

    文件目录

    vue3 非父子组件通信详解

    第一种方法

    App.vue

    <template>
      <div>
        <Home></Home>
        <button @click="addName">增加名字</button>
      </div>
    </template>
     <script>
    import Home from "./Home.vue";
    import { computed } from "vue";
    export default {
      name: "App",
      components: {
        Home,
      },
      provide() {
        return {
          name: "张三",
          age: 23,
          length: computed(() => this.names.length),
        };
      },
      data() {
        return {
          names: ["张三", "李四", "王五"],
        };
      },
      methods: {
        addName() {
          this.names.push("fuck you");
          console.log("hhhh");
        },
      },
    };
    </script>
     <style scoped>
    </style>
    

    Home.vue

    <template>
      <div>
        <div>我是home</div>
        <home-content></home-content>
      </div>
    </template>
     <script>
    import HomeContent from "./HomeContent.vue";
    export default {
      name: "Home",
      components: {
        HomeContent,
      },
    };
    </script>
     <style scoped>
    </style>
    

    HomeContent.vue

    <template>
      <div>HomeContent:{{ name }}--{{ age }}---{{ length }}</div>
    </template>
     <script>
    export default {
      inject: ["name", "age", "length"],
    };
    </script>
     <style lang="scss" scoped>
    </style>
    

    vue3中使用Provide函数和Inject函数

    事实上我们之前还学习过Provide和Inject,Composition API也可以替代之前的 Provide 和 Inject 的选项。

    我们可以通过 provide来提供数据:

    provide可以传入两个参数:

    name:提供的属性名称;

    value:提供的属性值;

    vue3 非父子组件通信详解

    在 后代组件 中可以通过 inject 来注入需要的属性和对应的值:

    可以通过 inject 来注入需要的内容;

    inject可以传入两个参数:

    要 inject 的 property 的 name;

    默认值;

    vue3 非父子组件通信详解

    数据的响应式

    为了增加 provide 值和 inject 值之间的响应性,我们可以在 provide 值时使用 ref 和 reactive。

    修改响应式Property

    如果我们需要修改可响应的数据,那么最好是在数据提供的位置来修改:我们可以将修改方法进行共享,在后代组件中进行调用;

    注意

    如果我们子组件应该是只能使用,不能修改的状态

    vue3 非父子组件通信详解

    总结

    本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注NICE源码的更多内容!

    免责声明:
    1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

    2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
    如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
    如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

    NICE源码网 JavaScript vue3 非父子组件通信详解 https://www.niceym.com/25711.html