浅析H5图片上传
概述
最近需求上需要实现图片上传的功能,简单记录下实现过程。目前实现的功能比较简单,主要有以下几点:
- 图片预览
- 图片删除
- 拖拽上传
- 压缩上传
移动端实现方案:使用File API
主要使用到 FileList、File、FileReader、canvas、拖放API
FileList对象
一个FileList对象通常来自于一个HTML input元素的files属性,你可以通过这个对象访问到用户所选择的文件。当用户通过file控件选取文件后,这个控件的files属性值就是FileList对象。它在结构上类似于数组,包含用户选取的多个文件。
通过表单控件获取FileList对象
通过监听onchange事件,选择图片后,可以通过files属性获取图片信息,其中accept属性为接收到文件格式,multiple 属性设置后支持选择多个文件。
<input type="file" name="demo" accept="image/jpeg,image/png" onchange="console.log(this.files.length)" multiple>
通过拖放获取FileList对象
DataTransfer对象是用于保存在一次拖放操作的被拖动的数据。通过DataTransfer.files属性可以获取所有在数据传输中可用的本地文件的列表。具体查看DataTransfer API和拖放API。
File对象
File API提供File对象,它是FileList对象的成员,包含了文件的一些元信息,比如文件名、上次改动时间、文件大小和文件类型。File对象文档。File对象的属性值如下:
- name:文件名,该属性只读。
- size:文件大小,单位为字节,该属性只读。
- type:文件的MIME类型,如果分辨不出类型,则为空字符串,该属性只读。
- lastModified:文件的上次修改时间,格式为时间戳。
- lastModifiedDate:文件的上次修改时间,格式为Date对象实例。
例如:
<input type="file" name="demo" accept="image/jpeg,image/png" onchange="upload()" multiple>
<script>
function upload(){
var file = document.querySelector('input').files[0];
document.writeln(file.name);
document.writeln(file.size);
document.writeln(file.type);
document.writeln(file.lastModified);
document.writeln(file.lastModifiedDate);
}
</script>
// 13910DAB-D0EC-4DE6-8876-CFAF9EDA3086.png
// 28345
// image/png
// 1500826120000
// Mon Jul 24 2017 00:08:40 GMT+0800 (CST)
FileReader 对象
FileReader 对象允许Web应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,它的参数是File对象或Blob对象。对于不同类型的文件,FileReader提供不同的方法读取文件。以下是相关方法及事件。详细查看api
方法
- readAsBinaryString(Blob|File):返回二进制字符串,该字符串每个字节包含一个0到255之间的整数。
- readAsText(Blob|File, opt_encoding):返回文本字符串。默认情况下,文本编码格式是’UTF-8’,可以通过可选的格式参数,指定其他编码格式的文本。
- readAsDataURL(Blob|File):返回一个基于Base64编码的data-uri对象。
- readAsArrayBuffer(Blob|File):返回一个ArrayBuffer对象。
事件处理
- Onabort :读取操作被中止时调用.
- Onerror :当读取操作发生错误时调用.
- Onload :当读取操作成功完成时调用.
- Onloadend :当读取操作完成时调用,不管是成功还是失败.该处理程序在onload或者onerror之后调用.
- Onloadstart:当读取操作将要开始之前调用.
- Onprogress :在读取数据过程中周期性调用.
创建一个FileReader对象
let reader = new FileReader();
readAsDataURL 读取图片
readAsDataURL方法返回一个data URL,它的作用基本上是将文件数据进行Base64编码。你可以将返回值设为图像的src属性。
<div class="imgPreview">
<img src="" width="100" height="100">
</div>
<input type="file" name="demo" accept="image/jpeg,image/png" onchange="upload()" multiple>
<script>
function upload(){
var file = document.querySelector('input').files[0];
var reader = new FileReader();
reader.onload = function(e){
// onload事件的回调函数接受一个事件对象,该对象的target.result就是文件的内容
document.querySelector('img').src = e.target.result;
};
reader.readAsDataURL(file);
}
</script>
浏览器兼容性
IE10以下的版本不支持FileReader()构造函数.不过可以利用滤镜来兼容旧版本的IE:兼容IE的图片本地预览.
第三方组件
需要兼容PC端可以使用webuploader组件
http://fex.baidu.com/webuploader/
参考资料
- https://www.ibm.com/developerworks/cn/web/1101_hanbf_fileupload/index.html
- http://www.techug.com/post/web-file-upload-method.html
- http://www.ruanyifeng.com/blog/2012/08/file_upload.html
- https://juejin.im/post/58c64f2b0ce463005479f4d3
- http://fex.baidu.com/webuploader/
- http://www.jq22.com/jquery-info230
- https://github.com/blueimp/jQuery-File-Upload/wiki/Setup
- https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader
- http://javascript.ruanyifeng.com/htmlapi/file.html
- https://www.w3.org/TR/FileAPI/
- https://developer.mozilla.org/zh-CN/docs/Web/API/File
- http://uule.iteye.com/blog/2281846
- http://www.zuojj.com/archives/1402.html
浅析H5图片上传的更多相关文章
- vuejs开发组件分享之H5图片上传、压缩及拍照旋转的问题处理
一.前言 三年.net开发转前端已经四个月了,前端主要用webpack+vue,由于后端转过来的,前端不够系统,希望分享下开发心得与园友一起学习. 图片的上传之前都是用的插件(ajaxupload), ...
- H5 图片上传
1.h5 图片异步上传 (1) 异步上传input触发onchange事件的时候,就把图片上传至服务器.后台可能会返回图片的链接等信息,前台可以把图片信息展示给用户看. (2) 另一种情况可能需要前台 ...
- h5图片上传预览与拖拽上传
图片上传: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w ...
- H5图片上传插件
基于zepto,支持多文件上传,进度和图片预览,用于手机端. (function ($) { $.extend($, { fileUpload: function (options) { var pa ...
- h5图片上传预览
项目中常用到文件上传预览功能,整理一下:如果不想使用 type="file" 的默认样式,可以让其覆盖在一个按钮样式上边,设其透明度为0,或者使用Label关联 html < ...
- h5图片上传简易版(FileReader+FormData+ajax)
一.选择图片(input的file类型) <input type="file" id="inputImg"> 1. input的file类型会渲染为 ...
- H5图片上传、压缩
1.注册input file标签的onchange事件: 2.检查图片格式: 3.检查图片大小: 4.压缩图片 5.上传图片至服务器: 前端代码: document.getElementById('i ...
- h5 图片上传旋转问题
https://blog.csdn.net/netdxy/article/details/51518494 https://www.cnblogs.com/liu-fei-fei/p/5974403. ...
- input file图片上传
<div class="div-title"> <h5>图片上传</h5> <div class="photo-box" ...
随机推荐
- 题解-Codeforces710F String Set Queries
咕了好久没更博客,最近得知可以去冬眠营玩耍,还可以搭顺风车回广州过年 (最近做到的比较有意思的题目:bzoj3958.hihocoder1419) Problem Codeforces-710F--洛 ...
- mysql开启binlog日志和慢查询日志
1)首先,为什么要开启binlog日志和慢查询日志呢? binlog日志会记录下数据库的所以增删改操作,当不小心删除.清空数据,或数据库系统出错,这时候就可以使用binlog日志来还原数据库,简单来说 ...
- Unity中的GC以及优化
[简介] 常见的 Unity GC 知识点总结出来的思维导图 Unity 官方文档,正巧在博客园发现了已经有位大神(zblade)把原文翻译出来了,而且质量很高~,译文地址 在这里.下面我就可耻地把译 ...
- 用Openssl计算ECDSA签名
ECDSA的全名是Elliptic Curve DSA,即椭圆曲线DSA.它是Digital Signature Algorithm (DSA)应用了椭圆曲线加密算法的变种.椭圆曲线算法的原理很复杂, ...
- 判断鼠标进入容器的方向小Demo
参考资料: 贤心博客:http://sentsin.com/web/112.html, Math.atan2(y,x) 解释 :http://www.w3school.com.cn/jsref/jsr ...
- python操作三大主流数据库(9)python操作mongodb数据库③mongodb odm模型mongoengine的使用
python操作mongodb数据库③mongodb odm模型mongoengine的使用 文档:http://mongoengine-odm.readthedocs.io/guide/ 安装pip ...
- elasticsearch索引自动清理
一 es 基本操作 查看所有的索引文件: curl -XGET http://localhost:9200/_cat/indices?v GET /_cat/indices?v DELETE /fi ...
- ORACLE透明加密
--官网文档:https://www.oracle.com/technetwork/cn/tutorials/tde-096009-zhs.html#t概述Oracle 数据库 10g 第 2 版透明 ...
- mysql 命令总结 每天5个
mysql -u root mysql> use mysql; mysql> UPDATE user SET Password = PASSWORD('newpass') WHER ...
- Struts2框架的概述及学习重点
什么是Struts2的框架 * Struts2是Struts1的下一代产品,是在 struts1和WebWork的技术基础上进行了合并的全新的Struts 2框架. * 其全新的Struts 2的体系 ...