multiple image upload and preview

柔情痞子 提交于 2019-12-20 10:55:58

问题


I am learning how to upload multiple images and showing their preview...

I came across the following code

<html>
<head>
<style>
.input-file-row-1:after {
content: ".";
display: block;
clear: both;
visibility: hidden;
line-height: 0;
height: 0;
}

.input-file-row-1{
display: inline-block;
margin-top: 25px;
position: relative;
}

#preview_image {
display: none;
width: 90px;
height: 90px;
margin: 2px 0px 0px 5px;
border-radius: 10px;
}

.upload-file-container { 
position: relative; 
width: 100px; 
height: 137px; 
overflow: hidden;   
background: url('images/picplus.png') top center no-repeat;
float: left;
margin-left: 23px;
} 

.upload-file-container-text{
font-family: Arial, sans-serif;
font-size: 12px;
color: #719d2b;
line-height: 17px;
text-align: center;
display: block;
position: absolute; 
left: 0; 
bottom: 0; 
width: 100px; 
height: 35px;
}

.upload-file-container-text > span{
border-bottom: 1px solid #719d2b;
cursor: pointer;
}

.one_opacity_0 {
opacity: 0;
height: 0;
width: 1px;
float: left;
}
</style>
<script>
function readURL(input,target)
{
if(input.files && input.files[0])
{
var reader=new FileReader();
var image_target=$(target);
reader.onload=function(e)
{
    image_target.attr('src',e.target.result).show();
};
reader.readAsDataUrl(input.files[0]);
}
}

$("patient_pic").live("change",function(){
readURL(this,"#preview_image")
});
</script>

</head>

<body>
<form name="" method="post" action="#" class="feedback-form-1">
<fieldset>
    <div class="input-file-row-1">
        <div class="upload-file-container">
            <img id="preview_image" src="#" alt="" />
            <div class="upload-file-container-text">
                <div class = 'one_opacity_0'>
                    <input type="file" id="patient_pic" label = "add" />
                </div>
                <span> Add Photo </span>
            </div>

<div class="upload-file-container-text">
                <div class = 'one_opacity_0'>
                    <input type="file" id="patient_pic" label = "add" />
                </div>
                <span> Add Photo </span>
            </div>

</div>
    </div>
</fieldset>
</form>
</body>

</html>

I came across this http://jsfiddle.net/dn9Sr/2/ (fiddle) which explains it perfectly to me. But being a beginner I know it includes a jquery library which clearly shows in framework extension of Fiddle. now my issue is. How exactly should I include it when I start the coding on my machine.

what will be included in the head() section to make a call to the library... thank you


回答1:


I have a solution to preview multiple image upload https://maraustria.wordpress.com/2014/04/25/multiple-select-and-preview-of-image-of-file-upload/

Html

<form id="post-form" class="post-form" method="post">
<label for=”files”>Select multiple files: </label>
<input id=”files” type=”file” multiple/>
<output id=”result” />
</form>

Javascript

window.onload = function(){
    //Check File API support
    if(window.File && window.FileList && window.FileReader)
    {
        var filesInput = document.getElementById(“files”);
        filesInput.addEventListener(“change”, function(event){
            var files = event.target.files; //FileList object
            var output = document.getElementById(“result”);
            for(var i = 0; i< files.length; i++)
            {
                var file = files[i];
                //Only pics
                if(!file.type.match(‘image’))
                    continue;
                var picReader = new FileReader();
                picReader.addEventListener(“load”,function(event){
                    var picFile = event.target;
                    var div = document.createElement(“div”);
                    div.innerHTML = “<img class=’thumbnail’ src=’” + picFile.result + “‘” +
                    “title=’” + picFile.name + “‘/>”;
                    output.insertBefore(div,null);
                });
                //Read the image
                picReader.readAsDataURL(file);
            }
        });
    }
    else
    {
        console.log(“Your browser does not support File API”);
    }
}

Css

body{
font-family: ‘Segoe UI’;
font-size: 12pt;
}

header h1{
font-size:12pt;
color: #fff;
background-color: #1BA1E2;
padding: 20px;

}
article
{
width: 80%;
margin:auto;
margin-top:10px;
}

.thumbnail{

height: 100px;
margin: 10px;
}

http://jsfiddle.net/0GiS0/Yvgc2/




回答2:


First include Jquery library in your <head> section

<script src="http://code.jquery.com/jquery-1.8.3.js" type="text/javascript"></script>

Then below that

<script>
$(function(){

//Here your function

});
</script>

Change in your function use on instead of live

$("patient_pic").on("change",function(){
readURL(this,"#preview_image")
});

jQuery has deprecated live() since 1.7, instead use on()




回答3:


Its as simple as :-

<html>
<head>
<script src="http://code.jquery.com/jquery-1.8.3.js" type="text/javascript"></script>
<script>

$(document).ready(function(){

//Your Code Goes Here

});

</script>
</head>
<body>
<!--Your H
</body>
</html>


来源:https://stackoverflow.com/questions/20779983/multiple-image-upload-and-preview

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!