Multiple Image Preview using jQuery

This tutorial will teach you how to preview multiple images before uploading using jQuery. Note: jQuery used in this tutorial is hosted, so, you might need internet connection for it to work.

index.html

This contains our input file that we have customize and our preview area.
  1. <!DOCTYPE html>
  2.         <title>Multiple Image Preview using jQuery</title>
  3.         <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
  4.         <link href="https://fonts.googleapis.com/css?family=Open+Sans" rel="stylesheet">
  5.         <link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">
  6.         <style>
  7.                 body{
  8.                         font-family: 'Open Sans', sans-serif;
  9.                 }
  10.                 .button {
  11.                 background-color: #4CAF50;
  12.                 border: none;
  13.                 color: white;
  14.                 padding: 16px 32px;
  15.                 text-align: center;
  16.                     text-decoration: none;
  17.                     font-size: 16px;
  18.                     margin: 4px 2px;
  19.                     cursor:pointer;
  20.                     font-family: 'Open Sans', sans-serif;
  21.                 }
  22.                 .main{
  23.                         margin-top:50px;
  24.                 }
  25.                 .hidden{
  26.                         display:none;
  27.                 }
  28.                 .h10{
  29.                         height:10px;
  30.                 }
  31.                 #filetext{
  32.                         margin-left:10px;
  33.                 }
  34.                 .title{
  35.                         font-size:25px;
  36.                 }
  37.                 .container {
  38.                 margin : 50px auto 0 auto;
  39.                         width:50%;
  40.         }
  41.         #filebutton{
  42.                 margin : 50px auto 0 auto;
  43.         }
  44.         #preview{
  45.                 margin-top:50px;
  46.         }
  47.         </style>
  48. </head>
  49. <div id="container">
  50.         <div class="main">
  51.                 <span class="title"><strong><center>Multiple Image Preview using jQuery</center></strong></span>
  52.                 <span><center>by <a href="https://www.sourcecodester.com/user/224918/track">nurhodelta_17</a></center></span>
  53.                 <div class="h10"></div>
  54.                 <input type="file" name="file" id="file" class="hidden" multiple>
  55.                 <center><button type="button" class="button" id="filebutton"><i class="fa fa-upload"></i><span id="filetext">Select File</span></button></center>
  56.                 <div id="preview"></div>       
  57.         </div>
  58. </div>
  59.         <script src="custom.js"></script>
  60. </body>
  61. </html>

custom.js

This contains our jQuery for the input file custom and image preview.
  1. $(document).ready(function(){
  2.         $('#filebutton').click(function(){
  3.                 $('#file').click();
  4.         });
  5.  
  6.         $('#file').change(function(){
  7.  
  8.                 var name = $(this).val().split('\\').pop();
  9.                 var file = $(this)[0].files;
  10.                 if(name != ''){
  11.                         if(file.length >=2){
  12.                                 $('#filetext').html(file.length + ' files ready to upload');
  13.                         }
  14.                         else{
  15.                                 $('#filetext').html(name);
  16.                         }
  17.                 }
  18.         });
  19.  
  20.         $('#file').on("change", previewImages);
  21. });
  22.  
  23. function previewImages() {
  24.  
  25.   var $preview = $('#preview').empty();
  26.   if (this.files) $.each(this.files, readAndPreview);
  27.  
  28.   function readAndPreview(i, file) {
  29.    
  30.     if (!/\.(jpe?g|png|gif)$/i.test(file.name)){
  31.       return alert(file.name +" is not an image");
  32.     } // else...
  33.    
  34.     var reader = new FileReader();
  35.  
  36.     $(reader).on("load", function() {
  37.       $preview.append($("<img>", {src:this.result, height:200}));
  38.     });
  39.  
  40.     reader.readAsDataURL(file);
  41.    
  42.   }
  43.  
  44. }

Add new comment