douwen1549 2012-02-21 16:17 采纳率: 100%
浏览 159

进度条显示加载百分比在ajax,php

Hi i am using ajax for loading database content .I want to display the total percentage of loading or image.

This is my Script

function name1(str)
{
if (str.length==0)
 {
  document.getElementById("txtHint").innerHTML="";
   return;
 }
if (window.XMLHttpRequest)
 {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
 }
else
 {// code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
 }
xmlhttp.onreadystatechange=function()
 {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
  {
   document.getElementById("txtHint").innerHTML=xmlhttp.responseText;
   }
 }
 xmlhttp.open("GET","user.php?q="+str,true);
xmlhttp.send();
}

user.php?q=ram , which is passing a value .And fetch the data from database How to modify ajax to to display the loading image

  • 写回答

1条回答 默认 最新

  • doutan5724 2012-02-21 16:30
    关注

    there is no easyway to do this, as you can not know the real size of the response by javascript.

    What you can do is: - make a first request to php, and have it send only the total bytes size of the image - then, inside your function name1(), you have to give the xmlhttp object a onprogress callback, HTML5 handles this:

    var totalsize = //get it from a initial post request
    
    xmlhttp.onprogress = function(response){
       var percentage = response.responseText.length / totalsize * 100;
       //update the progress bar, with that value...
    };
    

    then your onreadystatechange, handles the final chunk of data...

    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器