Oma*_*iri 6 url web-worker reactjs next.js
我正在尝试在 NextJs 中实现 Web Worker,我遵循了他们的示例,但是我无法将 Worker 相对 URL 作为变量传递给new URL(url, baseUrl)
.
以下代码片段是调用工作者的地方:
import { useEffect, useRef, useCallback } from 'react'
export default function Index() {
const workerRef = useRef()
useEffect(() => {
const workerUrl = '../worker.js';
console.log({
URL: new URL('../worker.js', import.meta.url),
meta: import.meta.url
});
console.log({
URL: new URL(workerUrl, import.meta.url),
meta: import.meta.url
});
workerRef.current = new Worker(new URL('../worker.js', import.meta.url))
workerRef.current.onmessage = (evt) =>
alert(`WebWorker Response => ${evt.data}`)
return () => {
workerRef.current.terminate()
}
}, [])
const handleWork = useCallback(async () => {
workerRef.current.postMessage(100000)
}, [])
return (
<div>
<p>Do work in a WebWorker!</p>
<button onClick={handleWork}>Calculate PI</button>
</div>
)
}
Run Code Online (Sandbox Code Playgroud)
这奇怪地记录:
{
"URL":"/_next/static/media/worker.3c527896.js",
"meta":"file:///home/omar/CODE/NextJs/lullo/with-web-worker-app/pages/index.js"
}
{
"URL":"file:///home/omar/CODE/NextJs/lullo/with-web-worker-app/worker.js",
"meta":"file:///home/omar/CODE/NextJs/lullo/with-web-worker-app/pages/index.js"
}
Run Code Online (Sandbox Code Playgroud)
这到底有什么不同:
const workerUrl = '../worker.js';
console.log({
URL: new URL('../worker.js', import.meta.url),
meta: import.meta.url
});
console.log({
URL: new URL(workerUrl, import.meta.url),
meta: import.meta.url
});
Run Code Online (Sandbox Code Playgroud)
问题是我无法将 URL 作为 prop 传递给某些通用的工作调用者。我收到恼人的错误:
SecurityError: Failed to construct 'Worker': Script at 'file:///home/omar/CODE/NextJs/lullo/client/src/utils/WebWorkers/postErrorToServer.ts' cannot be accessed from origin 'http://localhost:3000'.
Run Code Online (Sandbox Code Playgroud)
这可能会发生,因为在第一种情况下:
const workerUrl = '../worker.js';
const url = new URL(workerUrl, import.meta.url);
Run Code Online (Sandbox Code Playgroud)
webpack 将 URL 视为动态的,并且无法在编译时正确捆绑 Web Worker。如果您按如下方式定义工作人员,则会发生类似的情况:
const url = new URL('../worker.js', import.meta.url);
const worker = new Worker(url);
Run Code Online (Sandbox Code Playgroud)
对 webpack 的 GitHub 存储库中的讨论的评论可能对您的情况有所帮助。由于上述原因,我认为工作 URL 不能真正动态 - webpack 需要在编译时知道工作脚本的 url。
归档时间: |
|
查看次数: |
2041 次 |
最近记录: |