javascript – 是否存在Firefox Worker限制?

我试图创建Web Workers并在周期中向他们发布消息:
array.forEach(function (data) {
        this.createWorker();
        this.workers[this.workersPointer].postMessage({task: 'soMetask',data: string});
    },this);

createWorker函数

createWorker: function () {
    this.workersPointer++;
    var worker = this.workers[this.workersPointer] = new Worker('Worker.js'),storage = this;
    worker.onmessage = function (event) {
        if (event.data.error) {
            storage[event.data.task + 'Errback'](event.data.error);
        }
        else {
            storage[event.data.task + 'Callback'](event.data.data);
        }
    };
    worker.onerror = function (error) {
        storage.workerErrback(error);
    };
}

工人代码

self.addEventListener('message',function (event) {
self.postMessage({
    data: data,error: err,task: event.data.task
});

},false);

它在Google Chrome中完美运行.当我尝试在Firefox中运行它时,它只能运行20次. Firefox网络工作者有限制吗?我在mozilla.org上找不到有关它的信息.如果没有限制,问题是什么?有任何想法吗?

解决方法

刚做了一些我自己的测试.为此,我改变了一点代码

周期:

for(var i=0;i<200;i++){
   this.createWorker();
   this.workers[this.workersPointer].postMessage({task: 'soMetask',number:i});
};

createWorker函数

this.workers =[];
this.workersPointer = 0;
storage=[];


var createWorker= function () {
    workersPointer++;
    var myPointer = workersPointer;
    var worker = this.workers[this.workersPointer] = new Worker('Worker.js');

    worker.onmessage = function (event) {
        if (event.data.error) {
            alert(event.data.error);
        }
        else {
            document.cookie=event.data.task+"["+myPointer+"]="+event.data.number;
        }
    };
    worker.onerror = function (event) {
        alert("Error: " + event.error);
    };
}

工人:

onmessage = function(event) {
    postMessage({number:event.data.number*2,task: event.data.task});
};

在我运行之后,在chrome中我有66个cookie(包括一个漂亮的蓝色崩溃窗口),在firefox中我得到了20个.所以这两个浏览器似乎都有工作者限制.

编辑:

在Opera中我得到一个控制台消息:

此窗口超出了最大Web Worker实例数(16).

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...