如何使用Javascript/HTML进行简单的图像上传

use*_*903 53 html javascript jquery

有没有人知道如何进行简单的图像上传并在页面上显示它.

这就是我要找的东西.

  • 用户(我)将选择一个图像
  • 该页面将显示图像而不刷新页面或转到另一个文件.
  • 多个<img src>会做,因为我需要显示不同的图像大小.

这是我的代码.(其中一些是编辑的,我从这里得到它)

<style>
    /* Image Designing Propoerties */
    .thumb {
        height: 75px;
        border: 1px solid #000;
        margin: 10px 5px 0 0;
    }
</style>

<script type="text/javascript">
    /* The uploader form */
    $(function () {
        $(":file").change(function () {
            if (this.files && this.files[0]) {
                var reader = new FileReader();

                reader.onload = imageIsLoaded;
                reader.readAsDataURL(this.files[0]);
            }
        });
    });

    function imageIsLoaded(e) {
        $('#myImg').attr('src', e.target.result);
        $('#yourImage').attr('src', e.target.result);
    };

</script>


<input type='file' />
</br><img id="myImg" src="#" alt="your image" height=200 width=100>
Run Code Online (Sandbox Code Playgroud)

cla*_*e45 18

这是一个没有jQuery的简单示例.你可以用URL.createObjectURL,哪个

创建一个DOMString,其中包含表示参数中给定的对象的URL

然后,您只需将src图像设置为该URL,图像就会加载.

window.addEventListener('load', function() {
  document.querySelector('input[type="file"]').addEventListener('change', function() {
      if (this.files && this.files[0]) {
          var img = document.querySelector('img');  // $('img')[0]
          img.src = URL.createObjectURL(this.files[0]); // set src to blob url
          img.onload = imageIsLoaded;
      }
  });
});

function imageIsLoaded() { 
  alert(this.src);  // blob url
  // update width and height ...
}
Run Code Online (Sandbox Code Playgroud)
<input type='file' />
<br><img id="myImg" src="#" alt="your image" height=200 width=100>
Run Code Online (Sandbox Code Playgroud)

  • 也可以与反应一起使用,并且是非常简单的解决方案 (2认同)

HB *_*til 10

试试这个,它支持多文件上传,

$('#multi_file_upload').change(function(e) {
    var file_id = e.target.id;

    var file_name_arr = new Array();
    var process_path = site_url + 'public/uploads/';

    for (i = 0; i < $("#" + file_id).prop("files").length; i++) {

        var form_data = new FormData();
        var file_data = $("#" + file_id).prop("files")[i];
        form_data.append("file_name", file_data);

        if (check_multifile_logo($("#" + file_id).prop("files")[i]['name'])) {
            $.ajax({
                //url         :   site_url + "inc/upload_image.php?width=96&height=60&show_small=1",
                url: site_url + "inc/upload_contact_info.php",
                cache: false,
                contentType: false,
                processData: false,
                async: false,
                data: form_data,
                type: 'post',
                success: function(data) {
                    // display image
                }
            });
        } else {
            $("#" + html_div).html('');
            alert('We only accept JPG, JPEG, PNG, GIF and BMP files');
        }

    }
});

function check_multifile_logo(file) {
    var extension = file.substr((file.lastIndexOf('.') + 1))
    if (extension === 'jpg' || extension === 'jpeg' || extension === 'gif' || extension === 'png' || extension === 'bmp') {
        return true;
    } else {
        return false;
    }
}
Run Code Online (Sandbox Code Playgroud)

这里#multi_file_upload是图像上传字段的ID.

  • 这是Javascript代码.这不是PHP代码. (30认同)

小智 5

<img id="output_image" height=50px width=50px\
<input type="file" accept="image/*" onchange="preview_image(event)">

<script type"text/javascript">
  function preview_image(event) {
    var reader = new FileReader();
    reader.onload = function(){
      var output = document.getElementById('output_image');
      output.src = reader.result;
    }
    reader.readAsDataURL(event.target.files[0]);
  }
</script>
Run Code Online (Sandbox Code Playgroud)

  • 请在您的答案中添加解释,说明此代码的工作原理和方式。仅代码答案不是很有用,可能会导致 [cargo cult programming](https://en.wikipedia.org/wiki/Cargo_cult_programming)。 (9认同)