资讯专栏INFORMATION COLUMN

HTML5上传图片文件(含拖拽、预览、上传、美化)

JackJiang / 1061人阅读

摘要:本文讲细分讲述图片上传预览等。对象的类数组序列考虑多文件上传或者从桌面拖动目录或文件。可将文件分割为字节范围。

欢迎交换友链 Laker"s Blog--进击的程序媛
Github:https://github.com/younglaker
微博: 江小湖Laker

上篇文章讲了如何上传文件。本文讲细分讲述图片上传、预览等。

关于接口

File API

File - 独立文件;提供只读信息,例如名称、文件大小、mimetype 和对文件句柄的引用。

FileList - File 对象的类数组序列(考虑多文件上传或者从桌面拖动目录或文件)。

Blob - 可将文件分割为字节范围。

FileReader - 读取File或Blob

URL scheme

检测浏览器是否支持
// 检测是否支持File API
if (window.File && window.FileReader && window.FileList && window.Blob) {
  //  支持
} else {
  alert("不支持");
}
基本代码

选取一张图片,并预览:
Demo1



.preview_box img { width: 200px; } $("#img_input").on("change", function(e){ var file = e.target.files[0]; //获取图片资源 // 只选择图片文件 if (!file.type.match("image.*")) { return false; } var reader = new FileReader(); reader.readAsDataURL(file); // 读取文件 // 渲染文件 reader.onload = function(arg) { var img = ""; $(".preview_box").empty().append(img); } });

上传到服务器

var form_data = new FormData();
var file_data = $("#img_input").prop("files")[0];

// 把上传的数据放入form_data
form_data.append("user", "Mike");
form_data.append("img", file_data);

$.ajax({
    type: "POST", // 上传文件要用POST
    url: "",
    dataType : "json",
    crossDomain: true, // 如果用到跨域,需要后台开启CORS
  processData: false,  // 注意:不要 process data
  contentType: false,  // 注意:不设置 contentType
    data: form_data
}).success(function(msg) {
    console.log(msg);
}).fail(function(msg) {
    console.log(msg);
});
拖拽上传

三个相关事件:

dragenter

dragover

drop

原生JavaScript:

Demo2

Drop files here
    // 必须阻止dragenter和dragover事件的默认行为,这样才能触发 drop 事件 function fileSelect(evt) { evt.stopPropagation(); evt.preventDefault(); var files = evt.dataTransfer.files; // 文件对象 var output = []; // 处理多文件 for (var i = 0, f; f = files[i]; i++) { output.push("
  • ", escape(f.name), " (", f.type || "n/a", ") - ", f.size, " bytes, last modified: ", f.lastModifiedDate.toLocaleDateString(), "
  • "); } // 显示文件信息 document.getElementById("list").innerHTML = output.join(""); } function dragOver(evt) { evt.stopPropagation(); evt.preventDefault(); evt.dataTransfer.dropEffect = "copy"; } // 监听器 var dropZone = document.getElementById("drop_zone"); dropZone.addEventListener("dragover", dragOver, false); dropZone.addEventListener("drop", fileSelect, false);

    jQuery:

    其他代码可以不变,注意监听事件的时候的,由于jQuery的封装,数据存放的字段有变,传参是e.originalEvent而不是e

    $("#drop_zone").on("dragover", function(e){
      e.stopPropagation();
      e.preventDefault();
      handleDragOver(e.originalEvent);
    });
    
    $("#drop_zone").on("drop", function(e){
      e.stopPropagation();
      e.preventDefault();
      handleFileSelect(e.originalEvent);
    });
    美化上传框 方法一: 在隐藏的文件输入框上调用click()方法

    隐藏掉默认的的文件输入框元素,使用自定义的界面来充当打开文件选择对话框的按钮。要使用样式display:none把原本的文件输入框隐藏掉,然后在需要的时候调用它的click()方法就行了。

    
    选择文件
    
    var fileSelect = document.getElementById("fileSelect"),
      fileElem = document.getElementById("fileElem");
    
    fileSelect.addEventListener("click", function (e) {
      if (fileElem) {
        fileElem.click();  // jQuery可以使用 trigger()
      }
      e.preventDefault(); // prevent navigation to "#"
    }, false);
    方法二:用label

    隐藏input,把样式写到label上,点击label就是对input进行操作。

    Demo3

    
    
    
    #img_input2 { display: none; } #img_label2 { background-color: #f2d547; border-radius: 5px; display: inline-block; padding: 10px; } #preview_box2 img { width: 200px; }

    文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

    转载请注明本文地址:https://www.ucloud.cn/yun/79190.html

    相关文章

    • 基于Node的React图片上传组件实现

      摘要:常用的设置如下下的请求风格下的请求和不太一样,在正式的请求发出之前都会先发一个类型为的请求作为试探,只有当该请求通过以后,正式的请求才能发向服务端。所以服务端路由我们还需要处理这样一个请求注意该请求同样需要设置跨域。 写在前面 红旗不倒,誓把JavaScript进行到底!今天介绍我的开源项目 Royal 里的图片上传组件的前后端实现原理(React + Node),花了一些时间,希望对...

      cfanr 评论0 收藏0
    • 从0开始做一个的Vue图片/ 文件选择(上传)组件[基础向]

      摘要:当拖动的元素或文本选择离开有效的放置目标时,会触发此事件。以及对象在拖放交互期间传输的数据。 showImg(https://segmentfault.com/img/bVJQgt?w=1318&h=966); 17-3-2更新: 谢谢@mengdu 补充的关于图片预览的另一种更简单方法 URL.createObjectURL(),具体在文章里补充 之前用Vue做了一个基础的组件vue...

      Paul_King 评论0 收藏0

    发表评论

    0条评论

    JackJiang

    |高级讲师

    TA的文章

    阅读更多
    最新活动
    阅读需要支付1元查看
    <