关于 compositionApi 异步初始化的问题求教

2022-07-04 09:35:20 +08:00
 liangtao927190

各位大佬好,求教一个问题。

简单来说,我有一个 useXXX ,这个 useXXX 初始化的时候会从 api fetch 一些数据。

我在页面上多个组件里会使用这个 useXXX ,这就导致有 n 个用到 useXXX 的组件,就会初始化 n 次,fetch n 次。

目前我的想法是在 useXXX 里创建一个属性 loaded ,默认是 false ,初始化一次后就变成 true 这样来阻止后面的多次 fetch 。

不知道是否有更好的办法。

感谢各位

1787 次点击
所在节点    Vue.js
10 条回复
RockChang
2022-07-04 09:48:25 +08:00
只在一个组件生产,其余组件消费
L1shen
2022-07-04 09:49:13 +08:00
如果全局多个组件只需要一份这个数据,那就把这个 useXXX 放到全局的 store 里去
zhuangzhuang1988
2022-07-04 10:01:12 +08:00
已经放弃用 compositionApi 了
和 react hook 一样
心智负担重
auroraccc
2022-07-04 10:21:03 +08:00
你可能需要一个 https://vue-query.vercel.app/#/ 这样的东东?
liangtao927190
2022-07-04 10:23:41 +08:00
感谢楼上各位的回复,感觉都可以。

实话说 composition Api 我还是觉得挺好用的,至少 ui 和界面可以很好的拆开,就可以复用了。

就是很多用法感觉不太熟悉,包括 pinia 也还没有用。
Moeyua
2022-07-04 13:05:32 +08:00
也许可以尝试 provide 将数据提供给所有子组件,需要的组件使用 inject 将数据注入就可以了。
ccyu220
2022-07-04 13:11:27 +08:00
1 、顶级执行,然后子组件注入
2 、添加个手动执行的参数,例如 const { run } = useFunction({ manual: true })

@zhuangzhuang1988 这和哪个框架都没关系,这就是一个 JS 函数自动执行或手动出发的问题。真想不通上面你们的发言是怎么打出来的。
liangtao927190
2022-07-04 13:21:36 +08:00
@Moeyua 这个确实也有尝试,层级明确的的情况下挺好用的,但用了 useXXX 以后就习惯随意来,不需要关注父子级关系。
感谢。
liangtao927190
2022-07-04 13:21:51 +08:00
@ccyu220 感谢回复
huijiewei
2022-07-04 17:17:23 +08:00
1. 提升到 context
2. fetch 里面 cache

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

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

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

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

© 2021 V2EX