ajax如何实现进度条的效果?

发布于 2022-09-01 23:00:52 字数 591 浏览 23 评论 0

客户端发起一个ajax请求:
$("#data_container").load(server_url,{start_query_id:some_query_id});
要求服务器端需不断返回当前进度数据并返回至客户端,比如,客户端不断显示:当前查询的user_id是5,该用户信息是blahblahblah......
一开始我觉得很简单,ob_flush不就解决了嘛:
for($i=0;$i<100;$i++){
echo $i."<br/>";
flush();
ob_flush();
sleep(2);
}
结果,还是过了很久,然后PHP才一次性全部输出。想问一下这个错在哪?
这样不行的话,只能用iframe加载了,iframe内嵌页面通过ob_flush()解决时时输出当前查询的效果,但理论上浏览器的加载条会一直处于转圈圈状态,不合适。
剩下的只能是用ajax每返回一次数据便重新再提交一次query_id的形式,页面要不停请求服务器,请求时间也大幅增加,也加大了服务器负担。
用websocket,暂且不讨论他的浏览器可怜的兼容性了,PHP天生就不是干websocket的料吧。
然后,就不知道咋办了,有没有比较简单而且友好的处理这种问题的方式?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

隔纱相望 2022-09-08 23:00:52

ob_flush()和ajax并不是你想象的那种效果。

iframe内嵌页面通过ob_flush()可以实现你要的,但是有你说的"转圈圈"。
前端设置定时器,不断发送ajax请求,这是目前通行的做法。

要想优化ajax,可以查一下Commet。
另外,建议你思考一下你是否真的想要在一个大批量的耗时的操作里,一点点的输出每一个用户的所有信息。

勿挽旧人 2022-09-08 23:00:52

假进度条算法
完成进度条为100%
0 ~ 25% :随机递增 3% ~ 6% 每秒
25% ~ 65%:随机递增 0.1% ~ 3% 每秒
65% ~ 90%:随机递增 0.1% ~ 2% 每秒
90% ~ 99%:固定递增 0.5% 每秒

直到请求完成直接增长到100%

弥枳 2022-09-08 23:00:52

赞同 假进度条方法,我们以前就是这么干得。只要确保处理完毕后就是100%就行,中间速度爱咋咋地。

你如我软肋 2022-09-08 23:00:52

楼上说的假进度不错

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文