在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
前言: 在父子组件传递数据时,通常使用的是 props 和 emit,父传子时,使用的是 props,如果是父组件传孙组件时,就需要先传给子组件,子组件再传给孙组件,如果多个子组件或多个孙组件使用时,就需要传很多次,会很麻烦。 像这种情况,可以使用 一、Vue2 的 provide / inject 使用provide :是一个对象,里面是属性和值。如: provide:{ info:"值" } 如果 provide(){ return{ info: this.msg } }
inject: [ 'info' ] 接收上边 provide 提供的 info 数据,也可以是一个对象,该对象包含 from 和 default 属性,from 是可用做的注入内容中搜索用的 key,default 属性是指定默认值。 在 vue2 中 project / inject 应用: //父组件 export default{ provide:{ info:"提供数据" } } //子组件 export default{ inject:['info'], mounted(){ console.log("接收数据:", this.info) // 接收数据:提供数据 } }
二、Vue3 的 provide / inject 使用在组合式 provide 函数接收两个参数:
使用时: import { provide } from "vue" export default { setup(){ provide('info',"值") } } inject 函数有两个参数:
使用时: import { inject } from "vue" export default { setup(){ inject('info',"设置默认值") } } 完整实例1: //父组件代码 <script> import { provide } from "vue" export default { setup(){ provide('info',"值") } } </script> //子组件 代码 <template> {{info}} </template> <script> import { inject } from "vue" export default { setup(){ const info = inject('info') return{ info } } } </script> 三、添加响应性为了给 完整实例2: //父组件代码 <template> <div> info:{{info}} <InjectCom ></InjectCom> </div> </template> <script> import InjectCom from "./InjectCom" import { provide,readonly,ref } from "vue" export default { setup(){ let info = ref("今天你学习了吗?") setTimeout(()=>{ info.value = "不找借口,立马学习" },2000) provide('info',info) return{ info } }, components:{ InjectCom } } </script> // InjectCom 子组件代码 <template> {{info}} </template> <script> import { inject } from "vue" export default { setup(){ const info = inject('info') setTimeout(()=>{ info.value = "更新" },2000) return{ info } } } </script> 上述示例,在父组件或子组件都会修改
在订阅组件内修改值的时候,可以被正常修改,如果其他组件也使用该值的时候,状态容易造成混乱,所以需要在源头上规避问题。
使用方法: import { readonly } from "vue" let info = readonly('只读info值') setTimout(()=>{ info="更新info" //两秒后更新info的值 },2000) 运行两秒后,浏览器发出警告,提示 info 值不可修改。 所以我们就给 完整实例2的 provide 处添加 readonly 。 provide('info', readonly(info)) 在子组件修改值的时候,会有一个只读提醒。 修改值的时候,还是需要在 如: //发布 let info = ref("今天你学习了吗?") const changeInfo = (val)=>{ info.value = val } provide('info',readonly(info)) provide('changeInfo',changeInfo) //订阅 const chang = inject('changeInfo') chang('冲向前端工程师') 完整示例3:修改数据
// 父组件代码
<template>
<div>
info:{{info}}
<InjectCom ></InjectCom>
</div>
</template>
<script>
import InjectCom from "./InjectCom"
import { provide,readonly,ref } from "vue"
export default {
setup(){
let info = ref("今天你学习了吗?")
const changeInfo = (val)=>{
info.value = val
}
provide('info',readonly(info))
provide('changeInfo',changeInfo)
return{
info
}
},
components:{
InjectCom
}
}
</script>
//InjectCom 子组件代码
<template>
<div>
<button @click="chang('冲向前端工程师')">更新值</button>
</div>
</template>
<script>
import { inject } from "vue"
export default {
setup(){
const info = inject('info')
const chang = inject('changeInfo')
return{
info,
chang
}
}
}
</script>
到此这篇关于 |
请发表评论