当前位置:网站首页>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开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦
边栏推荐
猜你喜欢
Database: Organize Four Practical SQL Server Scripting Functions
电脑软件:推荐一款磁盘空间分析工具——WizTree
Network skills: teach you to install batteries on the router, you can still surf the Internet when the power is cut off!
JVM工具之 JPS
CMDB 腾讯云部分实现
目标检测中的IoU、GIoU、DIoU与CIoU
网络技巧:教你给路由器装上电池,断电照样可以上网!
微软电脑管家2.0公测版体验
Error occurred while trying to proxy request项目突然起不来了
A semi-supervised Laplace skyhawk optimization depth nuclear extreme learning machine for classification
随机推荐
90多款matlab工具箱打包放送
Implementation of ICEEMDAN Decomposition Code in MATLAB
53个全球免费学术资源数据库整理,查资料写论文必备【开学必备】
Centos通过Docker搭建MySQL的PXC集群
网络技巧:教你给路由器装上电池,断电照样可以上网!
QT 出现多冲定义问题
网络端口大全
unicloud 腾讯云 上传文件 Have no access right to the storage uniapp
指定区域内随机填充圆之matlab实现
网页中常用的两种绘图技术,用canvas绘图,绘制出一个三角形,矩形,柱状图,扇形图
狗都能看懂的Vision Transformer的讲解和代码实现
如何用matlab做高精度计算?【第二辑】
目标检测中的IoU、GIoU、DIoU与CIoU
对象的扩展补充
EfficientNet解读:神经网络的复合缩放方法(基于tf-Kersa复现代码)
A priori box (Anchor) in target detection
av_read_frame 阻塞,基于回调的解决办法
VS 2017编译 QT no such slot || 找不到*** 问题
数据库技巧:整理SQLServer非常实用的脚本
Jenkins pipeline 自动部署实践