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

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

ruisui885个月前 (01-07)技术分析37

父组件向子组件传值

父子组件传递数据时,通常使用的是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>

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/82.html

分享给朋友:

“Vue3,父组件子组件传值,provide(提供)和inject(注入)传值” 的相关文章

Vue3 如何实现父子组件传值?

在Vue 3中,要实现父子组件传值效果主要通过props和emit两种机制来实现,下面我们就来详细介绍一下这两种机制。父组件向子组件传值propsprops是Vue组件的一种机制,主要的作用就是实现从父组件向子组件传递数据值,在父组件上通过在子组件标签上定义属性来实现数据属性值的传递,在子组件中通过...

Java教程:gitlab-使用入门

1 导读本教程主要讲解了GitLab在项目的环境搭建和基本的使用,可以帮助大家在企业中能够自主搭建GitLab服务,并且可以GitLab中的组、权限、项目自主操作GitLab简介GitLab环境搭建GitLab基本使用(组、权限、用户、项目)2 GitLab简介GitLab是整个DevOps生命周期...

代码分支规范

一.gitflow工作流说明:主分支:master,稳定版本代码分支,对外可以随时编译发布的分支,不允许直接Push代码,只能请求合并(pull request),且只接受hotfix、release分支的代码合并。gitlab上做限制。热修复分支:hotfix,针对现场紧急问题、bug修复的代码分...

理解virt、res、shr之间的关系(linux系统篇)

前言想必在linux上写过程序的同学都有分析进程占用多少内存的经历,或者被问到这样的问题——你的程序在运行时占用了多少内存(物理内存)?通常我们可以通过top命令查看进程占用了多少内存。这里我们可以看到VIRT、RES和SHR三个重要的指标,他们分别代表什么意思呢?这是本文需要跟大家一起探讨的问题。...

你感动了吗?佳能超规格镜头 RF 24-105mm F2.8深度测评

如果要你选一支用作多题材创作的挂机镜头,那我相信很多人会选择24-105mm这个焦段的镜头。作为一支可以实现从广角到长焦的变焦镜头,24-105mm有着丰富的焦段选择。只是基于镜头体积以及光学结构上的限制,此前的24-105mm镜头只能恒定在F4的光圈。而佳能打破了这一限制,将实用焦段和恒定光圈完美...

史上最全 vue-router 讲解 !!!

前端路由 前端路由是后来发展到SPA(单页应用)时才出现的概念。 SPA 就是一个WEB项目只有一个 HTML 页面,一旦页面加载完成,SPA 不会因为用户的操作而进行页面的重新加载或跳转。 前端路由在SPA项目中是必不可少的,页面的跳转、刷新都与路由有关,通过不同的url显示相应的页面。 优点:前...