Comment déterminer si l'utilisateur a sélectionné un fichier pour le téléchargement ?

StackOverflow https://stackoverflow.com/questions/46219

  •  09-06-2019
  •  | 
  •  

Question

Si j'ai un

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

balise et un bouton de soumission, comment puis-je déterminer, dans IE6 (et supérieur) si un fichier a été sélectionné par l'utilisateur.

Dans FF, je fais juste :

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

Mais cela ne fonctionne pas dans IE.

Était-ce utile?

La solution

Cela fonctionne dans IE (et FF, je crois) :

if(document.getElementById("uploadBox").value != "") {
   // you have a file
}

Autres conseils

ce morceau de code fonctionne dans mon environnement local, j'espère qu'il fonctionnera également en live

var nme = document.getElementById("uploadFile");
if(nme.value.length < 4) {
    alert('Must Select any of your photo for upload!');
    nme.focus();
    return false;
}
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);"/>

Appelez cette fonction lors du changement.

Vous pouvez utiliser:

    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) }

Les trois donnent le même résultat.

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top