Как определить, выбрал ли пользователь файл для загрузки? - PullRequest
49 голосов
/ 05 сентября 2008

Если у меня есть

<input id="uploadFile" type="file" />

тег и кнопка отправки, как мне определить, в IE6 (и выше), был ли файл выбран пользователем.

В FF я просто делаю:

var selected = document.getElementById("uploadBox").files.length > 0;

Но это не работает в IE.

Ответы [ 4 ]

99 голосов
/ 05 сентября 2008

Это работает в IE (и FF, я считаю):

if(document.getElementById("uploadBox").value != "") {
   // you have a file
}
7 голосов
/ 03 марта 2014

этот фрагмент кода работает в моей локальной среде, надеюсь, он также будет работать вживую

var nme = document.getElementById("uploadFile");
if(nme.value.length < 4) {
    alert('Must Select any of your photo for upload!');
    nme.focus();
    return false;
}
3 голосов
/ 24 марта 2017
function validateAndUpload(input){
    var URL = window.URL || window.webkitURL;
    var file = input.files[0];

    if (file) {
        var image = new Image();

        image.onload = function() {
            if (this.width) {
                 console.log('Image has width, I think it is real image');
                 //TODO: upload to backend
            }
        };

        image.src = URL.createObjectURL(file);
    }
};​

<input type="file" name="uploadPicture" accept="image/*" onChange="validateAndUpload(this);"/>

Вызовите эту функцию при изменении.

0 голосов
/ 18 мая 2018

Вы можете использовать:

    var files = uploadFile.files;

    if (files.length == 0) { console.log(true) } else { console.log(false) }
    if (files[0] == undefined) { console.log(true) } else { console.log(false) }
    if (files[0] == null) { console.log(true) } else { console.log(false) }

Все три дают одинаковый результат.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...