当前位置:首页 > 技术文章 > 正文内容

Vue3,父组件子组件传值,provide(提供)和inject(注入)传值

zonemu23小时前技术文章2

父组件向子组件传值

父子组件传递数据时,通常使用的是props和emit,父向子传递使用props,子向父传递使用emit。

子组件接收3种方式

// 1、简单接收
props:["title","isShow"],
// 2、接收的同时对数据类型进行限制
props:{
  title:String,
  isShow:Boolean
},
// 3、最完整接收写法
props: {
  title: {
    type: String,
    default: "",
  },
  isShow: {
    type: Boolean,
    default: false,
  },
},

代码案例

父组件:demo04Manage.vue


<template>
  <div id="demo04">
    <h1>{{ name }}</h1>
    <Child :title="data.title" :isShow="data.isShow"></Child>
  </div>
</template>
<script>
import { ref, reactive } from "vue";
import Child from "./childComponent.vue";
//
export default {
  name: "demo04",
  components: {
    Child: Child,
  },
  setup(props, context) {
    // 名称
    let name = ref("父组件.Demo04");
    // 等价与const isShow = ref(true)
    let data = reactive({
      title: "Demo4测试案例",
      isShow: true,
    });
    // return出去
    return {
      name,
      data,
    };
  },
};
</script>

子组件:childComponent.vue

<template>
  <div id="demo04Child">
    <h3>{{ name }}</h3>
    <div class="menu">{{ title }}================={{ isShow }}</div>
  </div>
</template>
<script>
import { ref, reactive } from "vue";
//
export default {
  // 1、简单接收
  // props:["title","isShow"],
  // 2、接收的同时对数据类型进行限制
  // props:{
  //   title:String,
  //   isShow:Boolean
  // },
  // 3、最完整接收写法
  props: {
    title: {
      type: String,
      default: "",
    },
    isShow: {
      type: Boolean,
      default: false,
    },
  },
  setup(props, context) {
    //
    let name = ref("子组件.Demo04");
    //
    let data = reactive({
      //
    });
    // return出去
    return {
      name,
      data,
    };
  },
};
</script>

provide(提供)和inject(注入)传值

父传子时,使用的是props,如果父组件传子子组件时,先传给子组件,子组件再传给子子组件,如果多个子组件或多个子子组件使用时,就需要传很多次。像这种情况,可以使用provide()和inject()解决,不论组件嵌套多深,父组件都可以为所有子组件或子子组件提供数据,父组件使用provide()提供数据,子组件或子子组件inject()注入数据,同时兄弟组件之间传值更方便。

Composition API(组合式API)中使用:provide/inject,两个只能在setup期间调用,使用之前,必须从vue显示导入provide/inject方法。

Provide()

在setup中使用provide时,首先从vue显式导入provide 方法(import provide from ‘vue’),这个方法有两个属性 { name, value }。

Inject()

在setup函数中使用inject函数也需要显示的导入(import { inject } from ‘vue’),它也接受两个参数 { name, ‘默认值’(可选) };

代码案例

父组件:demo05Manage.vue


<template>
  <div id="demo05">
    <h1>{{ name }}</h1>
    <Child :title="title" :isShow="isShow"></Child>
  </div>
</template>
<script>
import { ref, reactive, provide, readonly } from "vue";
import Child from "./childComponent.vue";
//
export default {
  name: "demo05",
  components: {
    Child: Child,
  },
  setup(props, context) {
    // 名称
    let name = ref("父组件.Demo05");
    //
    provide("title", "Demo5测试案例");
    provide("isShow", readonly(true));
    // return出去
    return {
      name,
    };
  },
};
</script>

子组件:childComponent.vue

<template>
  <div id="demo05Child">
    <h3>{{ name }}</h3>
    <div class="menu">{{ title }}================={{ isShow }}</div>
  </div>
</template>
<script>
import { ref, reactive, inject } from "vue";
//
export default {
  // 1、简单接收
  // props:["title","isShow"],
  // 2、接收的同时对数据类型进行限制
  // props:{
  //   title:String,
  //   isShow:Boolean
  // },
  // 3、最完整接收写法
  props: {
    title: {
      type: String,
      default: "",
    },
    isShow: {
      type: Boolean,
      default: false,
    },
  },
  setup(props, context) {
    let name = ref("子组件.Demo05");
    //
    const title = inject("title");
    const isShow = inject("isShow");
    // return出去
    return {
      name,
      title,
      isShow,
    };
  },
};
</script>

相关文章

2020最新门店财务收支管理系统(通用版),直接套用,自动计算

连锁企业的财务不知道怎么做各门店的收支表,不会门店汇总,别着急,看这里,今天小编和大家分享一套2020最新最新门店财务收支系统(通用版),可以快速录入,自动计算,既方便又全面!希望对大家有所帮助!(文...

财务主管花了一周时间自制费用报销管理系统,是我见过最好用的

公司的费用报销又多又乱,一不小心就出错!头疼,财务主管花了一周时间自制费用报销管理台账,分类统计,重复报销还能自动提醒,真的少了很多麻烦!费用报销是财务日常工作必会面对的,各种票据太多太乱,搞的很烦,...

中信泰富&amp;明源云——搭建营销费用管理系统,实现3个在线化

3月23日,中信泰富地产与明源云合作的营销费用管理系统业务解决方案汇报在中信泰富大厦顺利结束。 (会议现场)这是自双方合作以来,继今年1月底项目启动会后的又一重要推进动作,本次汇报得到了双方领导的高度...

宽带客户收费管理系统--维修版(宽带售后服务)

宽带客户收费管理系统--维修版headerfooter《宽带客户收费管理系统——维修版》是一款适合宽带运营商使用的管理系统。软件主要包括以下功能:1.主要功能包括用户开户、收费录入、工单登记、故障处理...

一套智能停车场收费管理系统设计方案,拓扑图VISIO格式

大家好,我是薛哥。最近VIP会员群的读者咨询停车场管理系统的规划设计方案,今天分享一个模板素材,主要里面的拓扑图可以编辑的,VISIO格式,建议收藏备用。此套完整的Word方案,VIP会员下载!智能停...

智能停车场管理系统五种收费类型设置

智能停车场管理系统五种收费类型设置  点击智能停车场管理系统收费标准设置图标,出现下图所示对话框,在这个界面里面可以对停车场系统需要使用的收费标准进行个性化设置:共有五种收费类型(标准收费类、通用标准...