14

我必须使用 javascript 和 php 进行带宽测试,我使用 jQuery,并尝试所有浏览器,但是:

  • 火狐 - UP:7-8 Mbps
  • Explorer 9 - UP:7-8 Mbps
  • 歌剧 - UP:7-8 Mbps
  • Safari - UP:有时 800-900 kbps
  • Chrome - UP:100-200 kbps 或无数据

您有什么想法可以提高这些浏览器的性能或其他衡量速度的好技术吗?

sendFile: function (s, d, m){ // size, data, metric
    m++; // how many times I tried to post data
    console.log('m: '+m);
    time = new Date(); 
    endTime3=time.getTime(); // execute time start
    if(s<=65536){
        $.ajax({
            type : 'POST',
            url : '/vegpont/savszelesseg/',
            timeout: 30000,
            dataType: 'text',
            cache: false,
            data: {
                index : 3,
                text: d // large data, min 512 KB to 
            },
            success : function(data){
                console.log('kB: '+s);
                time = new Date(); 
                endTime4=time.getTime(); // execute time end
                console.log('sec: '+(endTime4-endTime3)/1000);
                if(((endTime4-endTime3)/1000)<sec){ // sec now equals 4
                    speedTest.createFile(s*2, m); // create a data which is 's' (aka size) large then call this sendfile method
                }else{
                    var delta=(endTime4-endTime3)/1000;
                    var res=Math.round(s/delta);
                    $('div#speedResult3').html('<b>UP:</b><br/>kB: '+s+', '+
                    'sec: '+delta+'<br/>' +
                    '<b>~ '+res*8+' kbps</b>');
                    $('div#speedResult3').slideDown(1000);
                    $('div.buttonContainer').unblock();
                }

            },
            error : function(XMLHttpRequest, textStatus, errorThrown) {
                if(textStatus=='timeout'){
                    if(m>10){
                        $('div#speedResult3').html('<b>UP:</b><br/>sikertelen mérés');
                        $('div#speedResult3').slideDown(1000);
                        $('div.buttonContainer').unblock();
                    }
                    else{
                        speedTest.createFile(s, m); // create a data which is 's' (aka size) large then call this sendfile method
                    }
                }
            }
        });
    }else{ ...
4

1 回答 1

2

根据我的个人经验,JQuery(和大多数 webkits)臃肿并导致许多问题,因为他们更关心重新发明轮子来制作自己的跨浏览器版本的功能,而不是提供检测到的优化扩展失踪。为此,出于多种原因,这些 webkits(又名 javascript api)会产生很多额外的开销。

我建议您尝试纯 JavaScript 原生 AJAX 调用,看看性能如何。

链接如何使用纯 javascript 完成此操作:

http://www.javascriptkit.com/dhtmltutors/ajaxgetpost.shtml

http://www.openjs.com/articles/ajax_xmlhttp_using_post.php

于 2012-09-23T02:14:37.383 回答