您现在的位置是:网站首页> 编程资料编程资料
vue2中provide/inject的使用与响应式传值详解_vue.js_
2023-05-24
305人已围观
简介 vue2中provide/inject的使用与响应式传值详解_vue.js_
前言
官网概念:这对选项需要一起使用,以允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深,并在其上下游关系成立的时间里始终生效。
一、基本用法
在父组件中使用provide传值,在子组件中用inject接收。
// 父组件 data() { return { name: "卷儿" } }, provide: function() { return { name: this.name } }, // 子组件 inject: ['name'],
这种方法传递过来的数据是没有响应性的,当你改变父组件中的name时,子组件中接收的name并不会改变。
官方解释:provide 和 inject 绑定并不是可响应的。这是刻意为之的。然而,如果你传入了一个可监听的对象,那么其对象的 property 还是可响应的。
二、响应式
1.方法一:传递的参数用一个方法返回
// 父组件 data() { return { name: "卷儿" } }, provide: function() { return { newName: () => this.name } // 子组件 inject: ['newName'], computed: { hnewName() { return this.newName() } } {{ hnewName }}
{{ newName() }}
2.方法二:把需要传递的参数定义成一个对象
官方解释:provide 和 inject 绑定并不是可响应的。这是刻意为之的。然而,如果你传入了一个可监听的对象,那么其对象的 property 还是可响应的。
// 父组件 data() { return { obj: { name: "卷儿" } } }, provide: function() { return { // 传递一个对象 obj: this.obj } }, // 子组件 inject: ['obj'], computed: { // 也可以不用计算属性重新定义 objName() { return this.obj.name } } obj的name: {{objName}}
obj的name: {{obj.name}}
总结
主要解决深层次的组件嵌套,祖先组件向子孙组件之间传值。
一层嵌套的父子组件可以使用props来传值,props本身就是有相应性的。
根据自身代码选择合适的传值方式,并不一定非要用provide/inject的传值。
到此这篇关于vue2中provide/inject使用与响应式传值的文章就介绍到这了,更多相关vue2 provide/inject响应式传值内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- Vue如何引用public中的js文件_vue.js_
- 浅析node中间件及实现一个简单的node中间件_node.js_
- JavaScript 中使用SpreadJS导入和导出 Excel 文件的方法_javascript技巧_
- JavaScript事件监听器详细介绍_javascript技巧_
- vue调用原生方法交互解读_vue.js_
- vue中常用的缩写方式_vue.js_
- sass在react中的基本使用(实例详解)_React_
- vue跳转后不记录历史记录的问题_vue.js_
- 开启Vue项目缺少node_models包的问题及解决_vue.js_
- 微信小程序引入外部icon(阿里巴巴矢量图标)的全过程_javascript技巧_
