vue3 composition api用法(vue3中provide和inject的使用)
vue3 composition api用法
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> <li> <h2>儿子组件</h2> <li>得到的值:{{getFaytherData}}</li> </li> <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> <li> <h2>孙子组件</h2> <li>得到的值{{getYeYeData}}</li> </li> </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。
到此这篇关于vue3中provide和inject的使用的文章就介绍到这了,更多相关vue provide和inject使用内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- vue导出动态的excel功能(vue中如何下载excel流文件及设置下载文件名)
- vue怎么操作表格(如何在在Vue3中使用markdown 编辑器组件)
- vue怎么引入axios(如何用vue封装axios请求)
- vue本地图片切换(vue动态加载本地图片的处理方法)
- vue组件方法里如何修改data(vue项目中使用rem替换px的实现示例)
- vue过滤器filters怎么用(如何使用vue过滤器filter)
- vue实现双向绑定原理(vue实现双向数据绑定)
- vue图片组件使用方法(Vue图片裁剪组件实例代码)
- vue路由跳转自动定位在哪里(Vue路由this.route.push跳转页面不刷新的解决方案)
- 详解Vue3中Teleport的使用(详解Vue3中Teleport的使用)
- vue element 表格上拉加载数据(Vue组件库ElementUI实现表格加载树形数据教程)
- vue怎么注册公共组件(解读Vue组件注册方式)
- vue动态路由实现权限控制(vue2/vue3路由权限管理的方法实例)
- vue3和vue2(Vue3对比Vue2的优点总结)
- vue实现列表向上滚动更新(vue实现列表无缝滚动)
- vue封装一个功能函数(vue中利用mqtt服务端实现即时通讯的步骤记录)
- 大女主 汤唯垂青电视圈,搭档朱亚文出演《大明皇妃孙若微传》(汤唯垂青电视圈)
- 红色代表什么(红色代表什么情感和含义)
- 高中数学题(高中数学题型总结及解题方法)
- 冰岛旅游攻略(冰岛旅游攻略及花费)
- 为什么现在年轻人越来越喜欢买衣服(为什么现在年轻人越来越喜欢买衣服穿)
- 怎么做好SEO(怎么做好seo内容优化)
热门推荐
- JS函数前面感叹号的作用
- canvas时钟代码(canvas实现烟花的示例代码)
- C#静态变量、静态方法、静态类
- python3web编程基础教程(python初学者,用python实现基本的学生管理系统python3代码实例)
- php教程微信支付技术(php微信扫码支付 php公众号支付)
- php抽奖功能(php+lottery.js实现九宫格抽奖功能)
- django框架教程第100讲(详解Django+Vue+Docker搭建接口测试平台实战)
- django框架运行流程(Django+Xadmin构建项目的方法步骤)
- javascript 开发网站(帮你提高开发效率的JavaScript20个技巧)
- 微信小程序数学公式(微信小程序计算器实例详解)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9