我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vue3中 provide 和 inject 用法及原理

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vue3中 provide 和 inject 用法及原理

前言:

在父子组件传递数据时,通常使用的是 props 和 emit,父传子时,使用的是 props,如果是父组件传孙组件时,就需要先传给子组件,子组件再传给孙组件,如果多个子组件或多个孙组件使用时,就需要传很多次,会很麻烦。

像这种情况,可以使用 provide inject 解决这种问题,不论组件嵌套多深,父组件都可以为所有子组件或孙组件提供数据,父组件使用 provide 提供数据,子组件或孙组件 inject 注入数据。同时兄弟组件之间传值更方便。

一、Vue2 的 provide / inject 使用

provide :是一个对象,里面是属性和值。如:


provide:{

 info:"值"

}

如果 provide 需要使用 data 内的数据时,这样写就会报错。访问组件实例 property 时,需要将 provide 转换为返回对象的函数。


provide(){

 return{

  info: this.msg

 }

}

inject :是一个字符串数组。如:


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) // 接收数据:提供数据

 }

} 

provide / inject 类似于消息的订阅和发布。provide 提供或发送数据, inject 接收数据。

二、Vue3 的 provide / inject 使用

在组合式 API 中使用 provide/inject,两个只能在 setup 期间调用,使用之前,必须从 vue 显示导入 provide/inject 方法。

provide 函数接收两个参数:

provide( name,value )

  • name:定义提供 property name
  • valueproperty 的值。

使用时:


import { provide } from "vue"

export default {

  setup(){

    provide('info',"值")

  }

}

inject 函数有两个参数:

inject(name,default)

  • name:接收 provide 提供的属性名。
  • default:设置默认值,可以不写,是可选参数。

使用时:


import { inject } from "vue"

export default {

  setup(){

    inject('info',"设置默认值")

  }

}

完整实例1provide/inject实例


//父组件代码

<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>

三、添加响应性

为了给 provide/inject 添加响应性,使用 ref reactive

完整实例2provide/inject 响应式


//父组件代码

<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>

上述示例,在父组件或子组件都会修改 info 的值。

provide / inject 类似于消息的订阅和发布,遵循 vue 当中的单项数据流,什么意思呢?就是数据在哪,修改只能在哪,不能在数据传递处修改数据,容易造成状态不可预测。

在订阅组件内修改值的时候,可以被正常修改,如果其他组件也使用该值的时候,状态容易造成混乱,所以需要在源头上规避问题。

readonly 只读函数,使用之前需要引入,如果给变量加上 readonly 属性,则该数据只能读取,无法改变,被修改时会发出警告,但不会改变值。

使用方法:


import { readonly } from "vue"

let info = readonly('只读info值')

setTimout(()=>{

 info="更新info" //两秒后更新info的值

},2000)

运行两秒后,浏览器发出警告,提示 info 值不可修改。

所以我们就给provide发射出去的数据,添加一个只读属性,避免发射出去的数据被修改。

完整实例2的 provide 处添加 readonly 。


provide('info', readonly(info))

在子组件修改值的时候,会有一个只读提醒。

修改值的时候,还是需要在 provide 发布数据的组件内修改数据,所以会在组件内添加修改方法,同时也发布出去,在子组件处调用就可以了。

如:


//发布

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>
 

到此这篇关于vue3provide inject 用法及原理的文章就介绍到这了,更多相关 vue3 中provide 和 inject 内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vue3中 provide 和 inject 用法及原理

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue3中的provide、inject的用法

这篇文章主要介绍了Vue3中的provide、inject的用法,需要的朋友可以参考下
2023-03-06

vue3中provide和inject怎么用

这篇文章将为大家详细讲解有关vue3中provide和inject怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.provide 和 inject 的讲解provide和inject可以实现嵌套组
2023-06-20

Vue3中Provide和Inject的实现原理是什么

这篇文章主要介绍了Vue3中Provide和Inject的实现原理是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue3中Provide和Inject的实现原理是什么文章都会有所收获,下面我们一起来看看吧
2023-06-29

Vue3插件中怎么使用Provide和Inject

今天小编给大家分享一下Vue3插件中怎么使用Provide和Inject的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。为什么
2023-07-04

vue3中provide和inject怎么使用

本篇内容主要讲解“vue3中provide和inject怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue3中provide和inject怎么使用”吧!前言:在父子组件传递数据时,通常
2023-06-21

Vue3中Provide/Inject的实现原理是什么

本文小编为大家详细介绍“Vue3中Provide/Inject的实现原理是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue3中Provide/Inject的实现原理是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来
2023-06-29

vue2和vue3中provide/inject的基本用法示例

Vue中的provide/inject是一种组件间通信的方式,它允许父组件向子组件传递数据,而不需要通过props或事件来实现,下面这篇文章主要给大家介绍了关于vue2/vue3中provide/inject的基本用法的相关资料,需要的朋友可以参考下
2023-05-17

vue中provide和inject怎么实现原理对抗平庸

本篇内容主要讲解“vue中provide和inject怎么实现原理对抗平庸”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue中provide和inject怎么实现原理对抗平庸”吧!provid
2023-07-06

一文搞懂vue中provide和inject实现原理对抗平庸

这篇文章主要为大家介绍了vue中provide和inject实现原理的深入理解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-05-16

一文聊聊Vue中provide和inject的使用方法

Vue中如何使用provide与inject?下面本篇文章就来给大家介绍一下Vue中provide和inject的使用方法,希望对大家有所帮助!
2023-05-14

vue3响应式原理之Ref用法及说明

这篇文章主要介绍了vue3响应式原理之Ref用法及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-12-03

编程热搜

目录