显示通过html表单上传的照片预览

时间:2014-09-06 23:58:34

标签: javascript jquery html image

我有一个表单,允许用户上传x个图像。当他们从计算机中选择图像时,可以单击一个按钮,这样他们就可以在提交表单之前预览图像。

有没有办法自动显示图像而无需单击预览按钮。目前,我正在使用JS .click功能,但我宁愿用户没有点击任何内容来查看他们上传的图片。

这是我正在使用的代码。

表格形式:

<div class="uploadWrapper">
    <p>Upload Images</p>
    <input type="file" name="files[]" multiple="true" id="files" style="left: 0px;" />
</div>
<input id="go" class="btn_img" type="button" value="Click to Preview Images">
<div id="images_upload"></div>
<script type="text/javascript">
    $("#files").click(function(){
        $(".btn_img").show();
    });
</script>

<?php include_once('upload/image-preview.php'); ?>

image-preview.php文件:

<script type="text/javascript">
function readURL(input) {
    if (input.files && input.files[0]) {
        var reader = new FileReader();

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

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

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


var reader = new FileReader(),
    i=0,
    numFiles = 0,
    imageFiles;


function readFile() {
    reader.readAsDataURL(imageFiles[i])
}

reader.onloadend = function(e) {


    var image = $('<img class="prev_img">').attr('src', e.target.result);
    $(image).appendTo('#images_upload');
    $( "#images_upload img" ).wrap( "<div class=\"an_image\">" );


    if (i < numFiles) {
        i++;
        readFile();
    }
};

$('#go').click(function() {

    imageFiles = document.getElementById('files').files

    numFiles = imageFiles.length;
    readFile();           

});
</script>

如果不必点击“点击预览图片”,我需要做什么?按钮看图像?

谢谢!

2 个答案:

答案 0 :(得分:2)

遍历input.files并为每个文件创建new FileReader()jsFiddle Demo

HTML

<input type='file' class="imageUpload" multiple="true" />
<div class="imageOutput"></div>

JS

$images = $('.images');

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

function readURL(input) {

    if (input.files && input.files[0]) {

        $.each(input.files, function() {
            var reader = new FileReader();
            reader.onload = function (e) {           
                $images.append('<img src="'+ e.target.result+'" />')
            }
            reader.readAsDataURL(this);
        });

    }
}

答案 1 :(得分:0)

谢谢@Brian

这就是我想出的。限制是10.

$images = $('#images_upload')

$(".imageUpload").change(function(event){
    readURL(this);
});

function readURL(input) {

    if (input.files[10]) {
        alert('You can uploaded a maximum of 10 images');
    } else {
        if (input.files && input.files[0]) {
            $.each(input.files, function() {
                var reader = new FileReader();
                reader.onload = function (e) {           
                    $images.append('<img src="'+ e.target.result+'" />')
                    }
                    reader.readAsDataURL(this);
                });
            }                                              
        }
    }