javascript - 在 VueJS / Javascript 中存储然后触发顺序事件的方式(承诺)
问题描述
什么是在 Javascript 上对事件进行排队,然后以正确的顺序(FIFO)一个接一个地触发它们的正确和最佳方法。
我做了这样的事情:
https://jsfiddle.net/zjsh0xq3/
我的组件正在从 Vuex / Vue 实例获取状态,并根据 DOM 位置进行同步(如果这些组件将从外部调整大小)。对于这个例子,我用List
项目的位置制作了组件,但想法是一样的。
ListItem
因此,在我在父组件上触发方法之后,List
将这些事件(用于操作的数据)存储在数组中。然后事件以正确的顺序一个接一个地触发,但前提是有一个从$emit
触发的回调说List
这个 List 的状态已经在 Vuex / Vue 实例中改变了。
有没有人有更好的想法来解决这种情况或在某个地方准备好用于排队事件的工具?
我想到了这篇文章中的承诺: https ://gist.github.com/anvk/5602ec398e4fdc521e2bf9940fd90f84
但我不知道如何防止在调用回调之前解决承诺。
感谢您的建议!
解决方案
推荐阅读
- javascript - 如何在 React-Native 中将两个选择器连接为城市区域?
- bash - 在当前目录中打开新终端
- javascript - 检查是否有任何标记可见
- swift - swift 中未启用适用于 iOS 的 Places API
- dll - 如何获得软件“关于”部分中显示的确切信息?
- c# - RadWindow WPF 中的 WndProc
- node.js - 选择集合在我的 nodejs 后端不起作用
- vue.js - ElementUI 消息框内使用的 vue 组件无法访问 vuex 存储
- laravel - SQLSTATE [42000]:语法错误或访问冲突:1055 'total_faci.Branch' 不在 GROUP BY 中(SQL:从 `dashboard_datas` 中选择 *)
- azure - 以编程方式在 Azure 存储上启用静态网站