87 votes

Comment prévisualiser l'image sélectionnée dans l'entrée type="file" dans une popup en utilisant jQuery ?

Dans mon code, j'autorise l'utilisateur à télécharger une image. Maintenant, je veux montrer cette image sélectionnée comme un aperçu dans ce même popup. Comment puis-je le faire en utilisant jQuery ?

Voici le type de saisie que j'utilise dans ma fenêtre popup.

Code HTML :

<input type="file" name="uploadNewImage">

220voto

Prabu Parthipan Points 1040

Démo

HTML :

 <form id="form1" runat="server">
   <input type='file' id="imgInp" />
   <img id="blah" src="#" alt="your image" />
</form>

jQuery

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

        reader.onload = function (e) {
            $('#blah').attr('src', e.target.result);
        }

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

$("#imgInp").change(function(){
    readURL(this);
});

Référence

48voto

geek Points 7054

Si vous utilisez HTML5, essayez l'extrait de code suivant

<img id="uploadPreview" style="width: 100px; height: 100px;" />
<input id="uploadImage" type="file" name="myPhoto" onchange="PreviewImage();" />
<script type="text/javascript">

    function PreviewImage() {
        var oFReader = new FileReader();
        oFReader.readAsDataURL(document.getElementById("uploadImage").files[0]);

        oFReader.onload = function (oFREvent) {
            document.getElementById("uploadPreview").src = oFREvent.target.result;
        };
    };

</script>

19voto

Abdo Host Points 9

Vous pouvez utiliser URL.createObjectURL

    function img_pathUrl(input){
        $('#img_url')[0].src = (window.URL ? URL : webkitURL).createObjectURL(input.files[0]);
    }

#img_url {
  background: #ddd;
  width:100px;
  height: 90px;
  display: block;
}

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<img src="" id="img_url" alt="your image">
<br>
<input type="file" id="img_file" onChange="img_pathUrl(this);">

2voto

MD Ashik Points 1534

Vérifiez mes scripts, ils fonctionnent bien :

  function handleFileSelect(evt) {
    var files = evt.target.files; // FileList object

    // Loop through the FileList and render image files as thumbnails.
    for (var i = 0, f; f = files[i]; i++) {

      // Only process image files.
      if (!f.type.match('image.*')) {
        continue;
      }

      var reader = new FileReader();

      // Closure to capture the file information.
      reader.onload = (function(theFile) {
        return function(e) {
          // Render thumbnail.
          var span = document.createElement('span');
          span.innerHTML = ['<img class="thumb" src="', e.target.result,
                            '" title="', escape(theFile.name), '"/>'].join('');
          document.getElementById('list').insertBefore(span, null);
        };
      })(f);

      // Read in the image file as a data URL.
      reader.readAsDataURL(f);
    }
  }

  document.getElementById('files').addEventListener('change', handleFileSelect, false);

#list img{
  width: auto;
  height: 100px;
  margin: 10px ;
}

-2voto

Prasanna Aarthi Points 1059

Vous pouvez utiliser le téléchargement ajax pour prévisualiser le fichier sélectionné http://zurb.com/playground/ajax-upload

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X