vuex 里面放置接口问题

2019-11-18 11:44:04 +08:00
 guorui112

在写某些列表刷新的时候,遇到了一些同步刷新的问题

a 页面:展示一个列表数据,只展示目前最新的前 5 条消息,不可翻页 b 页面:也是一个列表,在加载的时候展示 10 条信息,上拉触底后拉取新的数据 c 页面:列表详情页,在操作完之后刷新 a 页面和 b 页面的数据,我目前一直是 onshow 里面调用刷新的,然后因为每次展开详情页后,不管有没有操作,都需要刷新,出现一个加载的 loading 图标,感觉体验很不好,在小程序中也遇到的同样的问题,onshow 会每次都刷新,如果用页面之间的事件传递,也很麻烦(小程序中想用 redux ), 目前有想法是在 vuex 同步一下状态,统一更新关于这些消息的列表,但是具体实现上很迷茫,比方说,如何放置数据,是分 3 个对象去接受 a b c 的数据,还是统一一个列表去接收,还有接口之类的放在 store 哪里

907 次点击
所在节点    问与答
1 条回复
redbuck
2019-11-18 14:20:01 +08:00
接口专门建一个文件统一放置.比如 api.js

store 里只建一个 list 存数据.一个 flag 决定是否清空数据.一个查询对象 query,包含 pageIndex 等
它负责获得 dispatch 后用 api 去拉取数据.如果数据存在就直接返回成功.如果 flag 要清空数据就重置 query,清空 list

a 页面,派发一个 dispatch 获取一页数据.
b 页面,不断派发 dispatch 获取多页数据.
c 页面,操作结束设置 flag

页面利用 getters 或者页面本身的 computed 去动态展示 list 里对应的数据.

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

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

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

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

© 2021 V2EX