V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
TomeWong
V2EX  ›  程序员

Electron: web worker 批量上传文件,如何将 web woker 信息实时回传至 worker 主进程

  •  
  •   TomeWong · 2020-04-28 16:36:56 +08:00 · 1098 次点击
    这是一个创建于 1681 天前的主题,其中的信息可能已经有所发展或是发生改变。

    目前是通过 postMessage 回传变化的信息,需要显示上传的进度,在 web worker 子进程中,如果上传的信息和状态

    发生了变化,就会实时将这部分信息通过 postMessage 回传至 worker 主进程,同时通过 vuex dispatch 将这部

    分上传进度信息更新至进度条更新组件中,但由于使用的是 dispatch 异步的,即使使用 await 仍然没有用,导致

    web worker 中上传都完成了,显示进度条的列表仍未收到上传进度更新的信息

        worker.onmessage = async event => {
            const { uuid, md5, taskDataArr, completeStatus } = event.data
            if(completeStatus.status === 'updateStore') {
                await store.dispatch('task/addMultiTaskUL', taskDataArr)
            } else if(completeStatus.status === 'updateTaskUL') {
                await store.dispatchPromise('task/updateTaskUL', { uuid, md5 })
            } else if(completeStatus.status === 'failTaskUL') {
                await store.dispatch('task/failTaskUL', uuid)
            } else {
                await store.dispatch('task/completeTaskUL', uuid)
            }
        }
    

    各位大佬有遇到这种问题么?

    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1069 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 19:16 · PVG 03:16 · LAX 11:16 · JFK 14:16
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.