私自身のテストを書いた。stackoverflowでコードをテストしましたが、正常に動作し、chrome / FFは6を実行できることがわかります
var change = 0;
var simultanius = 0;
var que = 20; // number of tests
Array(que).join(0).split(0).forEach(function(a,i){
var xhr = new XMLHttpRequest;
xhr.open("GET", "/?"+i); // cacheBust
xhr.onreadystatechange = function() {
if(xhr.readyState == 2){
change++;
simultanius = Math.max(simultanius, change);
}
if(xhr.readyState == 4){
change--;
que--;
if(!que){
console.log(simultanius);
}
}
};
xhr.send();
});
さまざまなタイミングでreadystate changeイベントをトリガーできるほとんどのWebサイトで機能します。(別名:フラッシング)
node.jsサーバーで、イベント/フラッシュをトリガーするために少なくとも1025バイトを出力する必要があることに気付きました。そうでなければ、イベントはリクエストが完了したときに一度に3つの状態すべてをトリガーするだけなので、ここに私のバックエンドがあります。
var app = require('express')();
app.get("/", function(req,res) {
res.write(Array(1025).join("a"));
setTimeout(function() {
res.end("a");
},500);
});
app.listen(80);
更新
xhrとfetch apiの両方を同時に使用している場合は、最大で2倍のリクエストを処理できることに気づきました
var change = 0;
var simultanius = 0;
var que = 30; // number of tests
Array(que).join(0).split(0).forEach(function(a,i){
fetch("/?b"+i).then(r => {
change++;
simultanius = Math.max(simultanius, change);
return r.text()
}).then(r => {
change--;
que--;
if(!que){
console.log(simultanius);
}
});
});
Array(que).join(0).split(0).forEach(function(a,i){
var xhr = new XMLHttpRequest;
xhr.open("GET", "/?a"+i); // cacheBust
xhr.onreadystatechange = function() {
if(xhr.readyState == 2){
change++;
simultanius = Math.max(simultanius, change);
}
if(xhr.readyState == 4){
change--;
que--;
if(!que){
document.body.innerHTML = simultanius;
}
}
};
xhr.send();
});