当前位置:网站首页>Provide 和 Inject 的用法
Provide 和 Inject 的用法
2022-08-04 05:36:00 【m0_67402026】
前言
父子组件传参可以通过props和emit来实现,但是当组件的层次结构比较深时,props和emit就没什么作用了。vue为了解决这个提出了Provide / Inject,知道这个东西,但是一直没用过,最近碰到了一个问题,踩了一些坑,在这里记录一下
备注:
我安装的是vue3.x,v-model用的是3.x的语法。
2.x和3.x用法一致,我这里是用2.x写的
通用知识
基本用法
provide 选项应该是:一个对象或返回一个对象的函数
inject 选项应该是:一个字符串数组,或 一个对象,对象的 [key] 是本地的绑定名
provide 和 inject 绑定并不是可响应的。这是刻意为之的。
代码执行顺序
data->provide->created->mounted
基本代码
主要使用grandpa和grandson这两个组件,son在这里充当一个层级
//grandpa.vue
<template>
<div>
<h3 style="margin-bottom: 20px">爷爷组件</h3>
<el-button type="primary" @click="lookDetail">查看</el-button>
<!-- 儿子组件 -->
<son v-model:visible="openDialog"></son>
</div>
</template>
<script>
import Son from "./son.vue";
export default {
components: { Son },
data() {
return {
message: "aa",
openDialog: false,
};
},
methods: {
lookDetail() {
this.openDialog = true;
},
},
};
</script>
//son.vue
<template>
<div>
<el-dialog v-model="visible" title="父组件" width="50%" append-to-body @close="closeDialog">
<el-button type="primary" @click="lookDetail">查看</el-button>
</el-dialog>
<!-- 孙子组件 -->
<grandson v-model:visible="openDialog"></grandson>
</div>
</template>
<script>
//孙子组件
import grandson from "./grandson.vue";
export default {
components: {
grandson,
},
props: {
visible: {
type: Boolean,
default: false,
},
},
emit: ["update:visible"],
data() {
return {
openDialog: false,
};
},
methods: {
closeDialog() {
this.$emit("update:visible", false);
},
lookDetail() {
this.openDialog = true;
},
},
};
</script>
//grandson.vue
<template>
<div>
<el-dialog v-model="visible" title="孙子组件" width="30%" @close="closeDialog">
</el-dialog>
</div>
</template>
<script>
export default {
props: {
visible: {
type: Boolean,
default: false,
},
},
emit: ["update:visible"],
data() {
return {};
},
methods: {
closeDialog() {
this.$emit("update:visible",false)
},
},
};
</script>
如图:
基础用法: 传个字符串
简单修改一下组件
//grandpa.vue
export default {
components: { Son },
provide:{
grandpaMsg:'哈哈哈'
}
//grandson.vue
<template>
<div>
<el-dialog v-model="visible" title="孙子组件" width="30%" @close="closeDialog">
<div>
信息:{
{grandpaMsg}}
</div>
</el-dialog>
</div>
</template>
<script>
export default {
props: {
visible: {
type: Boolean,
default: false,
},
},
inject:['grandpaMsg'],
数据过来了,如图:
中级用法
传个字符串没啥用,如果要传data里的一个属性呢?简单修改一下组件
//grandpa.vue
components: { Son },
provide:{
grandpaMsg:this.message
},
data() {
return {
message: "aa",
openDialog: false,
};
},
嗯,直接报错,哈哈哈。
如果要使用data里的参数,需要这样写
//grandpa
components: { Son },
provide(){
return {
grandpaMsg:this.message
}
},
结果:
高级用法
一开始就说了这个不是响应式,简单看一下
<h3 style="margin-bottom: 20px">爷爷组件</h3>
<el-button type="primary" @click="lookDetail">查看</el-button>
<el-button type="primary" @click="message='abcde'">改变数据</el-button>
如图:
那如何变成响应式的呢,再简单改一下
//grandpa
provide(){
return {
grandpaMsg:()=>this.message
}
},
//grandson
<el-dialog v-model="visible" title="孙子组件" width="30%" @close="closeDialog">
<div>
信息:{
{grandpaMsg()}}
</div>
</el-dialog>
如图:

拓展:你可以直接传一个this过去,这样孙子组件会获得爷爷组件的实例对象,这种方式也是响应式的
provide(){
return {
grandpaMsg:this
}
},
先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦
边栏推荐
- 2DCNN, 1DCNN, BP, SVM fault diagnosis and result visualization of matlab
- Implementation of ICEEMDAN Decomposition Code in MATLAB
- 如何画好业务架构图。
- mysql月份比較是否相等
- QT QOpenGLWidget 全屏导致其他控件显示问题
- 对象的扩展补充
- 狗都能看懂的Pytorch MAML代码详解
- MAML原理讲解和代码实现
- RuntimeError: You called this URL via POST, but the URL doesn‘t end in a slash and you have APPEND_S
- 元素的增删克隆以及利用增删来显示数据到页面上
猜你喜欢

Centos通过Docker搭建MySQL的PXC集群

华硕飞行堡垒系列无线网经常显示“无法连接网络” || 一打开游戏就断网

如何用matlab做高精度计算?【第一辑】

基于EEMD+GRU+MLR的时间序列预测

Interpretation of EfficientNet: Composite scaling method of neural network (based on tf-Kersa reproduction code)

JVM工具之 JPS

unicloud 腾讯云 上传文件 Have no access right to the storage uniapp

基于时序模式注意力机制(TPA)的长短时记忆(LSTM)网络TPA-LSTM的多变量输入风电功率预测

Different lower_case_table_names settings for server (‘1‘) and data dictionary (‘0‘) 解决方案

微软电脑管家2.0公测版体验
随机推荐
MySQL(4)
Operating System Random
sql常用函数
如何用matlab做高精度计算?【第一辑】
DropBlock: 卷积层的正则化方法及复现代码
JVM调优实践
网页中常用的两种绘图技术,用canvas绘图,绘制出一个三角形,矩形,柱状图,扇形图
狗都能看懂的Pytorch MAML代码详解
Centos通过Docker搭建MySQL的PXC集群
MATLAB 的ICEEMDAN分解代码实现
如何用matlab做高精度计算?【第二辑】
天鹰优化的半监督拉普拉斯深度核极限学习机用于分类
GRNN、RBF、PNN、KELM之间究竟有什么联系?
解决腾讯云DescribeInstances api查询20条记录以上的问题
90多款matlab工具箱打包放送
53个全球免费学术资源数据库整理,查资料写论文必备【开学必备】
YOLOv3详解:从零开始搭建YOLOv3网络
【音视频开发系列】fdk_aac 之 PCM 转 AAC
golang 的库引用方法
【C# - 爬虫】使用Selenium实现爬虫,获取近七天天气信息(包含完整代码)