简体   繁体   English

setInterval()仅触发一次

[英]setInterval() fires only once

I'm trying to update a variable every 500ms when an image upload starts and sets its value as 100 when the uploading completes. 我尝试在图像上传开始时每500毫秒更新一次变量,并在上传完成时将其值设置为100。 Here's the code: 这是代码:

var progress = 0
var $new = document.querySelector('#new');
var $imgupload = document.querySelector('#img-upload');
var $progress = document.querySelector('#progress');
var $percent = document.querySelector('#percent');
var interval = null;

function incrementProgress() {
    interval = window.setInterval(function() {
        $percent.innerHTML = progress+'%'
        $progress.setAttribute('value', progress)
        progress += 2;
        console.log('fired') // fires only once
    }, 500)
}

function readURL(input) {
    if (input.files && input.files[0]) {
        var reader = new FileReader();

        reader.onload = function (e) {
            var $img = document.querySelector('#new');
            $img.setAttribute('src', e.target.result);
            $img.style.display = 'block';
        }

        reader.readAsDataURL(input.files[0]);
    }
}

//triggers the setInterval() and initiates image uploading

$imgupload.addEventListener('change', function() {
    incrementProgress();
    readURL(this);
});


//clears the setInterval() on image upload and sets the progress value as 100.

$new.addEventListener('load', function() {
    window.clearInterval(interval);
    $percent.innerHTML = 100+'%'
    $progress.setAttribute('value', 100)
})

The Problem: 问题:

As soon as the image uploading starts, the value of $progress gets set to 0 and jumps directly to 100 once the image gets uploaded. 图像上传开始后, $progress的值将设置为0并在图像上传后直接跳至100 What's expected is that the $progess variable increments by 2 every 500ms which is not happening. 可以预期的是, $progess变量每500ms递增2 ,这是没有发生的。

Edit: 编辑:

Here's the working fiddle: 这是工作的小提琴:

https://jsfiddle.net/7tmcu5g6/1/ https://jsfiddle.net/7tmcu5g6/1/

Perhaps true progression would be better? 也许真正的进步会更好? Simply replace setInterval with reader.onprogress : 只需将setInterval替换为reader.onprogress

 var $new = document.querySelector('#new'); var $imgupload = document.querySelector('#img-upload'); var $progress = document.querySelector('#progress'); var $percent = document.querySelector('#percent'); function readURL(input) { if (input.files && input.files[0]) { var reader = new FileReader(); reader.onprogress = function (e) { var progress = Math.round((e.loaded / e.total) * 100); $percent.innerHTML = progress + "%"; $progress.setAttribute('value', progress); } reader.onload = function (e) { var $img = document.querySelector('#new'); $img.setAttribute('src', e.target.result); $img.style.display = 'block'; } reader.readAsDataURL(input.files[0]); } } $imgupload.addEventListener('change', function () { readURL(this); }); $new.addEventListener('load', function () { $percent.innerHTML = 100 + '%' $progress.setAttribute('value', 100) }) 
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js"></script> <progress max="100" value="0" id="progress"></progress> <span id="percent">0%</span> <label for="img-upload">Upload</label> <input type="file" accept=".jpg, .jpeg, .png" id="img-upload"> <img src='#' id='new' width="200" height="200" style="display: none"> 

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM