当前位置:Gxlcms > PHP教程 > php如何实现进度条

php如何实现进度条

时间:2021-07-01 10:21:17 帮助过:39人阅读

php实现进度条的方法:1、利用“输出缓冲控制”直接输出进度条;2、利用ajax先去请求逻辑处理的地址,然后利用session或者其他存储介质保存处理进度。

推荐:《PHP视频教程》

php实现进度条主要有两种方式,一种是利用“输出缓冲控制”直接输出进度条,还有一种是ajax方式

首先说一下“输出缓冲控制”方式:

该方式主要利用php的几个缓冲函数,该方式可以不用更改配置文件,直接运行即可,下面贴出代码:

  1. <?php
  2. set_time_limit(0); //设置程序执行时间
  3. ignore_user_abort(true); //设置断开连接继续执行
  4. header('X-Accel-Buffering: no'); //关闭buffer
  5. header('Content-type: text/html;charset=utf-8'); //设置网页编码
  6. ob_start(); //打开输出缓冲控制
  7. echo str_repeat(' ',1024*4); //字符填充
  8. $width = 1000;
  9. $html = '<div style="margin:100px auto; padding: 8px; border: 1px solid gray; background: #EAEAEA; width: %upx"><div style="padding: 0; background-color: white; border: 1px solid navy; width: %upx"><div id="progress" style="padding: 0; background-color: #FFCC66; border: 0; width: 0px; text-align: center; height: 16px"></div></div><div id="msg" style="font-family: Tahoma; font-size: 9pt;">正在处理...</div><div id="percent" style="position: relative; top: -34px; text-align: center; font-weight: bold; font-size: 8pt">0%%</div></div>';
  10. echo sprintf($html, $width+8, $width);
  11. echo ob_get_clean(); //获取当前缓冲区内容并清除当前的输出缓冲
  12. flush(); //刷新缓冲区的内容,输出
  13. $length = 11;
  14. for($i=0; $i<$length; $i++) {
  15. sleep(rand(1,2));
  16. $proportion = ($i+1)/$length;
  17. if($i+1 == $length){
  18. $msg = '同步完成';
  19. }else{
  20. $msg = '正在同步第' . ($i+1) . '个用户';
  21. }
  22. $script = '<script>document.getElementById("percent").innerText="%u%%";document.getElementById("progress").style.width="%upx";document.getElementById("msg").innerText="%s";</script>';
  23. echo sprintf($script, intval($proportion*100), intval(($i+1)/$length)*$width, $msg);
  24. echo ob_get_clean(); //获取当前缓冲区内容并清除当前的输出缓冲
  25. flush(); //刷新缓冲区的内容,输出
  26. }

注:该进度条样式是从网上找的,稍微修改了下,你可以替换成自己想要的样式

“ajax方式”则稍微麻烦点,该方法的逻辑是利用ajax先去请求(最好是异步请求)”逻辑处理”的地址,逻辑处理过程中利用session或者其他存储介质(比如memcache,redis等)保存处理进度,在用ajax去请求(最好是同步请求)另一个查询进度的地址,实现实时反馈

下面贴出代码:
首先是html文件

  1. <!DOCTYPE html><html><head><meta charset="UTF-8"><script type="text/javascript" src="./jquery-1.10.2.min.js"></script><title>同步</title></head><body>
  2. <input type="button" name="syn" id="syn" value="同步" />
  3. <div id="progressBar" style="margin: 50px auto; padding: 8px; border: 1px solid gray; background: #EAEAEA; width: 1008px;display:none">
  4. <div style="padding: 0; background-color: white; border: 1px solid navy; width: 1000px">
  5. <div id="progress" style="padding: 0; background-color: #FFCC66; border: 0; width: 0px; text-align: center; height: 16px"></div>
  6. </div>
  7. <div id="msg">正在处理...</div>
  8. <div id="percent" style="position: relative; top: -18px; text-align: center; font-weight: bold; font-size: 8pt">0%</div>
  9. </div></body><script>function query(timestamp){
  10. $.ajax({
  11. type:'post',
  12. url:'/test1.php', //查询进度
  13. data:{ timestamp:timestamp},
  14. dataType: "json",
  15. async:false,
  16. success: function(data){
  17. if(data.code=='10000'){
  18. data1 = data.data;
  19. document.getElementById("percent").innerText= data1.percent + "%";
  20. document.getElementById("progress").style.width=data1.progress + "px";
  21. document.getElementById("msg").innerText=data1.msg; if(data1.percent == 100){
  22. $("#syn").attr('disabled', false); return ;
  23. }
  24. }else{
  25. document.getElementById("msg").innerText=data.msg;
  26. }
  27. setTimeout('query(' + timestamp + ')', 1000);
  28. }
  29. });
  30. }
  31. $("#syn").click(function(){
  32. var timestamp = Date.parse(new Date());
  33. $("#syn").attr('disabled', 'disabled');
  34. $("#progressBar").css('display', 'block');
  35. $.ajax({
  36. type:'post',
  37. url:'/test.php', //执行处理
  38. data:{ timestamp:timestamp},
  39. dataType: "json",
  40. async:true,
  41. success: function(data){
  42. if(data.code=='10000'){
  43. console.log('同步成功'); //data1 = data.data;
  44. //document.getElementById("percent").innerText= data1.percent + "%";
  45. //document.getElementById("progress").style.width=data1.progress + "px";
  46. //document.getElementById("msg").innerText=data1.msg;
  47. }else{
  48. document.getElementById("msg").innerText=data1.msg;
  49. }
  50. }
  51. });
  52. setTimeout('query(' + timestamp + ')', 1000);
  53. });</script></html>
  1. test.php
  2. <?php
  3. set_time_limit(0); //设置程序执行时间
  4. ignore_user_abort(true); //设置断开连接继续执行
  5. $timestamp = $_POST['timestamp']; //省略一切校验
  6. $width = 1000;
  7. $length = 11;
  8. for($i=0; $i<$length; $i++) {
  9. sleep(rand(1,2)); //模拟处理时间
  10. $proportion = ($i+1)/$length;
  11. if($i+1 == $length){
  12. $msg = '同步完成';
  13. }else{
  14. $msg = '正在同步第' . ($i+1) . '个用户';
  15. }
  16. $data = array(
  17. 'percent' => intval($proportion*100),
  18. 'progress' => intval($width*($i+1)/$length),
  19. 'msg' => $msg
  20. );
  21. session_start();
  22. $_SESSION['now_percent' . $timestamp] = $data;
  23. session_write_close(); //释放session锁
  24. }
  25. echo json_encode(array(
  26. 'code' => 10000,
  27. 'data' => $data
  28. ));
  1. test1.php
  2. <?php
  3. //忽略所有校验,直接写主要部分
  4. $timestamp = $_POST['timestamp']; //省略一切校验
  5. session_start();
  6. $now_percent = @$_SESSION['now_percent' . $timestamp];
  7. session_write_close();
  8. if(empty($now_percent)){
  9. echo json_encode(array(
  10. 'code' => 10001,
  11. 'msg' => '正在处理...'
  12. ));exit;
  13. }else{
  14. echo json_encode(array(
  15. 'code' => 10000,
  16. 'data' => $now_percent
  17. ));exit;
  18. }

注:1、之所以未用setinterval定时去查而用setTimeout是因为如果设置的时间过短,而请求响应时间过长就会出现显示混乱
2、使用session后要注意及时释放,不然查询时会因为session被锁而一直等待,使用完就释放是最好的

以上就是php如何实现进度条的详细内容,更多请关注gxlcms其它相关文章!

人气教程排行