在 Vue 里, props 传入 Object 或 Array 的最佳实践是什么?

2023-07-01 20:51:34 +08:00
 llbbzh

如果一个 Vue 组件接受一个 Object 或者 Array 作为 prop ,那在这个组件内部处理该 prop 时就会有很多种写法,我很好奇,到底哪种是最佳实践呢?

从组件使用该 prop 的方式来看,可以分成两种类型:

从组件向外发布新数据的方式看,又能分成三种类型:

这几种写法各有优缺点,你的项目用的是什么写法?最推荐的写法到底是啥?

979 次点击
所在节点    问与答
8 条回复
ruoxie
2023-07-01 21:19:54 +08:00
vue react 都写的用的是不可变对象型
z4oSkDNGGC2svsix
2023-07-01 21:43:24 +08:00
可以简化为, 组件是否修改 prop 中的对象, 如果修改, 如何通知父组件.

1. 如果组件不修改 prop 对象, 当然可以直接使用, 如果你是函数式原教旨主义者, 你还可以克隆一遍
2. 当 prop 近乎于组件独有的状态时, 可以直接修改, 例如表格列开关状态, 这个状态除了这个表格, 其他地方不会用到.
3. 如果外部需要知道有状态产生变化, 但并不依赖该状态的值, 可以修改后通知. 比如有一个更新视口的函数, 在表格列开关后, 它会更新页面宽度. 这个函数并不在乎具体哪个列产生了变化.
4. 当状态被多个地方依赖时, 用不可变对象会更加稳健. 所有的组件只修改克隆版, 修改后 emit 新的值.
5. 可以无脑用不可变对象. 啰嗦且性能也不好.
ChefIsAwesome
2023-07-01 22:17:11 +08:00
比方讲你把一个组件里的一部分拆出来变成一个子组件。你不是为了复用功能,而是为了分解逻辑才拆分。拆分之前,对子组件这部分代码来说,它修改 data(state)。所以没有理由一模一样的代码,放到新文件里就要做事件、克隆之类的操作,直接修改 prop 就对了。
另外 vue 的事件是一对一的。父组件订阅子组件事件,等同于父组件传一个函数给子组件执行。
vivipure
2023-07-01 22:19:39 +08:00
虽然官方推荐不要直接修改 props , 但实际应用中,如果传入的是引用的话,子组件修改也无所谓的。反正 Vue 是有依赖收集的,并不强调不可变性。
在常见的表单场景下,我就习惯将部分独立的属性,用子组件拆分进行控制。修改后再通知实在繁琐,且没多大必要。
mineralsalt
2023-07-01 22:43:25 +08:00
我也很好奇这两种写法哪个对? 我一般都用第 2 个, 因为可以传入基本类型和自定义对象
1: defineProps({val: Number})
2:: defineProps<{val: number}>()
tianzi123
2023-07-03 17:18:43 +08:00
你写的貌似有问题吧 , 内部状态型 里说 用 watch 监听/? 如果用了 ref 为啥不用 const data = toRef(data) 直接 就是响应式的,另外单项数据流我觉得还是要遵守,这是一个良好的书写习惯,特别是团队合作,虽然有时候可以偷懒,但不利于长期维护
tianzi123
2023-07-03 17:21:41 +08:00
@tianzi123 另外,父组件的数据一般都是调接口获取,我个人写法,一般都是 子组件更新值了,直接通知父组件重新调用接口获取,这样最省事也符合规范,特别是弹窗多的页面,比如说一个页面 10 个弹窗,父组件一个更新函数搞定
charlie21
2023-07-12 09:34:31 +08:00
@Livid may be worth moving to /go/vue

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/953312

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX