当前位置:网站首页>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开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦
边栏推荐
- U-Net详解:为什么它适合做医学图像分割?(基于tf-Kersa复现代码)
- 事件链原理,事件代理,页面的渲染流程,防抖和节流,懒加载和预加载
- Unable to preventDefault inside passive event listener due to target being treated as passive. See
- QT QOpenGLWidget 全屏导致其他控件显示问题
- 如何画好业务架构图。
- 叔本华的《人生的智慧》感悟
- 基于EEMD+GRU+MLR的时间序列预测
- FCN——语义分割的开山鼻祖(基于tf-Kersa复现代码)
- VS 2017编译 QT no such slot || 找不到*** 问题
- 搭建redis哨兵
猜你喜欢
随机推荐
七夕专属程序员的浪漫
微软电脑管家2.0公测版体验
读取JDBC配置文件
golang rtsp拉流测试
IoU, GIoU, DIoU and CIoU in target detection
无监督特征对齐的迁移学习理论框架
原型图总结规范
NelSon:一款新的适配matlab编程语法的编程工具
如何在Excel 里倒序排列表格数据 || csv表格倒序排列数据
mysql月份比較是否相等
sql常用函数
IDEA中创建编写JSP
基于时序模式注意力机制(TPA)的长短时记忆(LSTM)网络TPA-LSTM的多变量输入风电功率预测
this关键字,构造函数
软件稳定性思考
狗都能看懂的CenterNet讲解及代码复现
Time Series Forecasting Based on Reptile Search RSA Optimized LSTM
Database Skills: Organize SQL Server's Very Practical Scripts
unicloud 腾讯云 上传文件 Have no access right to the storage uniapp
MATLAB 的ICEEMDAN分解代码实现









