PHP 实现进度条

使用的是PHP的ob 函数实现

具体函数可参考 PHP官方文档Output Control 函数

前端使用了iframe具体代码如下

ob_function.php


if (ob_get_level() == 0) {
    ob_start();
}
$progress = 0;
while ($progress < 100) {
    $progress += rand(1, 20);
    if ($progress > 100) {
        $progress = 100;
    }
    echo "<script>parent.updateProgress({$progress});</script>";
    echo str_pad('',4096)."\n";
    ob_flush();
    flush();
    sleep(1);
}
ob_end_flush();

ob.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<button id="start">开始</button>
<div id="name"></div>

</body>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/1.12.4/jquery.js"></script>
<script>
    $(function () {
        $('#start').click(function () {
            if ($('#my-iframe').length == 0) {
                $('body').append('<iframe style="display: none" id="my-iframe" src="/ob_function.php"></iframe>');
            }
        });
    });
    function updateProgress(progress) {
        $('#name').html(progress + '%');
        if (progress == 100) {
            $('#my-iframe').remove();
        }
    }
</script>

</html>

服务器如果是nginx 需要修改nginx配置文件 在http 块里面增加或修改

proxy_buffering off;
gzip off;
fastcgi_keep_conn on;

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值