Kendi testimi yazdım. stackoverflow kodu test, iyi çalışıyor bana krom / FF yapabileceğini söyler 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();
});
farklı zamanlarda readystate değişiklik olayını tetikleyebilen çoğu web sitesi için çalışır. (aka: kızarma)
Node.js sunucumda, olayı / yıkamayı tetiklemek için en az 1025 bayt çıktısını almak zorunda olduğumu fark ettim. Aksi takdirde, istek tamamlandığında olaylar üç durumu da aynı anda tetikler;
var app = require('express')();
app.get("/", function(req,res) {
res.write(Array(1025).join("a"));
setTimeout(function() {
res.end("a");
},500);
});
app.listen(80);
Güncelleme
Hem xhr hem de api'yi aynı anda kullanıyorsanız, artık 2x'e kadar isteğiniz olabileceğini fark ediyorum
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();
});