分享更有价值
被信任是一种快乐

Vue的provide/inject如何用

文章页正文上

这篇文章主要讲解了“Vue的provide/inject如何用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue的provide/inject如何用”吧!
简单的可以把provide/inject对比为React的context,都是为了解决跨层级传递属性的不方便而设立的,跟早期的context一样,一开始provide/inject机制也没有载入官方文档,现在虽然已经写了,但仍是语焉不详,这就是我写本文的目的。
Hello World
看一个最简单的例子,从祖辈组件中拿到传入下来的颜色值
UI界面如上,很简单,祖辈组件还提供了一个单选来改变。


红色


绿色

先看provide,它可以是一个对象,比如
provide: {
color: “green”
}
在孙子组件中可以顺利的取到这个值,但要注意的是这样子的写法是不能返回Vue实例的响应式数据的,当尝试改为
provide: {
color: this.color, //访问不到Vue实例
}
发生错误,提示是Uncaught TypeError: Cannot read property ‘color’ of undefined 。
一般还是用函数的方式,返回一个传入的对象
provide() {
return {
color: this.color,
};
}
但是color不是响应式的,就是说如果我在祖辈组件里选择另外一个颜色,在孙子组件里是拿不到更新后的值的,关于非响应式这一点在下一节详细展开。
inject用来指定一个数组或者一个对象,数组的话就放provide里字段的名称,而对象的话可以指定
当前实例中的字段名
对应provide里的字段名
默认值或者返回默认值的函数
const Child = {
inject: {
foo: {
from: ‘bar’,
default: () => [1, 2, 3]
}
}
}
不是响应式
这个跟React的context是不同的,React没有响应式机制,一旦改变属性后默认会引发层层的渲染,开发者自己通过shouldComponentUpdate来优化。
官方文档上明确的说了
provide和inject绑定并不是可响应的。这是刻意为之的。然而,如果你传入了一个可监听的对象,那么其对象的 property 还是可响应的。
第一种解决方案是把值转为函数,记得要用箭头函数,不然不能正确获取this
provide() {
return {
color: () => {
return this.color;
},
};
}
然后使用时就要变成了函数的调用

这样子就带来一个很明显的缺点就是由于不是响应式,这个函数将会被调用多次,比如上面模板里有两个color(),可以在函数里打个断点,会发现进来两次。
更好一些的解决方案是把provide所在的Vue实例给传递下去,再来改造一下
provide() {
return {
color: this,
};
}
在孙组件免费云主机、域名里获得的其实是实例了,所以要多取一层属性

可以看到很多UI组件库就是通过这个方式来传递属性的,因为有可能在不确定层级的子组件里要获得祖组件里的值。感谢各位的阅读,以上就是“Vue的provide/inject如何用”的内容了,经过本文的学习后,相信大家对Vue的provide/inject如何用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是云技术,小编将为大家推送更多相关知识点的文章,欢迎关注!

相关推荐: div如何使用

本篇内容主要讲解“div如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“div如何使用”吧!到此,相信大家对“div如何使用”有了更深的了解,不妨来实际操作一番吧!这里是云技术网站,更多相关内容可以进入相关频…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册