本文主要是介绍vue中数据传递的inject 和provide,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
处理Vuex 还有一种数据存储传递方案
如果注入的是一个对象或数组 则由于引用类型的关系, 父子组件公用一个数据源,修改任意一方都会修改数据
如父组件
provide () {return {'name': this.$data}},
子组件
inject: ['name']
另外一种情况 父子组件注入的是一个基本数据类型 如字符串,数字 ,布尔, 则只会传递初始值,并且在子组件修改数据会报错。
Avoid mutating an injected value directly since the changes will be overwritten whenever the provided component re-renders. injection being mutated: "name"
依赖注入 injec和provide 以下引用官方
provide / inject
2.2.0 新增
-
类型:
- provide:
Object | () => Object
- inject:
Array<string> | { [key: string]: string | Symbol | Object }
- provide:
-
详细:
provide
和inject
主要在开发高阶插件/组件库时使用。并不推荐用于普通应用程序代码中。这对选项需要一起使用,以允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深,并在起上下游关系成立的时间里始终生效。如果你熟悉 React,这与 React 的上下文特性很相似。
provide
选项应该是一个对象或返回一个对象的函数。该对象包含可注入其子孙的属性。在该对象中你可以使用 ES2015 Symbols 作为 key,但是只在原生支持Symbol
和Reflect.ownKeys
的环境下可工作。inject
选项应该是:- 一个字符串数组,或
- 一个对象,对象的 key 是本地的绑定名,value 是:
- 在可用的注入内容中搜索用的 key (字符串或 Symbol),或
- 一个对象,该对象的:
from
属性是在可用的注入内容中搜索用的 key (字符串或 Symbol)default
属性是降级情况下使用的 value
提示:
provide
和inject
绑定并不是可响应的。这是刻意为之的。然而,如果你传入了一个可监听的对象,那么其对象的属性还是可响应的。 -
示例:
// 父级组件提供 'foo' var Provider = {provide: {foo: 'bar'},// ... }// 子组件注入 'foo' var Child = {inject: ['foo'],created () {console.log(this.foo) // => "bar"}// ... }
利用 ES2015 Symbols、函数
provide
和对象inject
:const s = Symbol()const Provider = {provide () {return {[s]: 'foo'}} }const Child = {inject: { s },// ... }
接下来 2 个例子只工作在 Vue 2.2.1 或更高版本。低于这个版本时,注入的值会在
props
和data
初始化之后得到。使用一个注入的值作为一个属性的默认值:
const Child = {inject: ['foo'],props: {bar: {default () {return this.foo}}} }
使用一个注入的值作为数据入口:
const Child = {inject: ['foo'],data () {return {bar: this.foo}} }
在 2.5.0+ 的注入可以通过设置默认值使其变成可选项:
const Child = {inject: {foo: { default: 'foo' }} }
如果它需要从一个不同名字的属性注入,则使用
from
来表示其源属性:const Child = {inject: {foo: {from: 'bar',default: 'foo'}} }
与 prop 的默认值类似,你需要对非原始值使用一个工厂方法:
const Child = {inject: {foo: {from: 'bar',default: () => [1, 2, 3]}} }
这篇关于vue中数据传递的inject 和provide的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!