html5 通过xhr生成上传下载进度条

HTML5 通过 XHR2(XMLHttpRequest Level 2)对象提供了一种方便的方式来上传和下载文件,并且可以同时追踪文件的进度。所以,我们可以用 XHR2 对象来实现上传下载进度条。

下面是一个简单的例子:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>上传下载进度条</title>
</head>
<body>
    <div>
        <h3>上传文件</h3>
        <input type="file" id="file">
        <progress id="upload-bar" value="0" max="100"></progress>
    </div>
    <div>
        <h3>下载文件</h3>
        <button id="download">下载</button>
        <progress id="download-bar" value="0" max="100"></progress>
    </div>

    <script>
        var xhr;

        function uploadFile() {
            var fileInput = document.getElementById('file');
            var progressBar = document.getElementById('upload-bar');

            xhr = new XMLHttpRequest();
            xhr.upload.addEventListener('progress', function(event) {
                if (event.lengthComputable) {
                    var percentage = Math.round((event.loaded * 100) / event.total);
                    progressBar.value = percentage;
                }
            }, false);

            xhr.onreadystatechange = function() {
                if (xhr.readyState === 4) {
                    if (xhr.status === 200) {
                        alert('上传成功');
                        progressBar.value = 0;
                    } else {
                        alert('上传失败');
                    }
                }
            };

            xhr.open('POST', 'upload.php', true);
            xhr.send(fileInput.files[0]);
        }

        function downloadFile() {
            var progressBar = document.getElementById('download-bar');

            xhr = new XMLHttpRequest();
            xhr.addEventListener("progress", function(event) {
                if (event.lengthComputable) {
                    var percentage = Math.round((event.loaded * 100) / event.total);
                    progressBar.value = percentage;
                }
            }, false);

            xhr.onreadystatechange = function() {
                if (xhr.readyState === 4) {
                    if (xhr.status === 200) {
                        alert('下载成功');
                    } else {
                        alert('下载失败');
                    }
                    progressBar.value = 0;
                }
            };

            xhr.open('GET', 'download.php', true);
            xhr.responseType = 'blob';
            xhr.send();
        }

        document.getElementById('file').addEventListener('change', uploadFile);
        document.getElementById('download').addEventListener('click', downloadFile);
    </script>
</body>
</html>

在上面的例子中,我们定义了一个 uploadFile 函数来上传文件,并且在上传过程中更新进度条。我们还定义了一个 downloadFile 函数来下载文件,并且在下载过程中更新进度条。最后,我们使用 addEventListener 来监听上传文件和下载文件的事件。

总结来说,HTML5 提供了一种简单、方便的方式来上传下载文件,并且可以追踪文件的进度。我们可以使用 XHR2 对象来实现上传下载进度条。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@小白—

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值