用html5文件api实现移动端图片上传&预览效果
想要用h5在移动端实现图片上传&预览效果,首先要了解html5的文件api相关知识(所有api只列举本功能所需):
1.Blob对象
Blob表示原始二进制数据,Html5的file对象就继承于它,它提供以下属性:
type:mime类型,如果是未知类型则返回一个空字符串
size:Blob对象的字节长度
2.input(type=“file”)控件与file&FileList对象
<input type="file" accept="image/*” multiple id=“file"/>
见上述代码:
multiple:表示file控件允许一次放置多个文件
accept:用来让input只能接受某种类型的文件,但是目前主流浏览器对其的支持都只局限于打开文件选择窗口时,默认选择图片文件而已,如果其他类型文件,file控件也能正常接受。所以要单独加判断:
input file控件有如下两个属性:
name:文件名,不包含路径(悲催的是iphone返回的文件名都是image.***)
lastModifiedDate:文件的最后修改日期
file:控件内用户选择的每一个文件都是一个file对象
FileList:为file对象的列表,访问方法如下:
var files = document.getElementById("file").files
判断代码如下:
for(var k=0;k<files.length;k++){ if(!/image\/\w+/.test(files[k].type)){ alert(files[k].name+"不是图像文件!"); }else{ //此处可加入文件上传的代码 alert(files[k].name+"文件已上传”) } }
3.FileReader接口
Filereader接口主要用于把文件读入内存,并且读取文件中的数据,FileReader接口提供了一个异步接口(用于在浏览器主线程中异步访问文件系统),浏览器对FileReader的能力检测代码如下:
if(typeof FileReader == undefined) { div.innerHTML = "不支持filereader"; }else{ div.innerHTML = "FileReader is ok”; }
FileReader的方法
readAsDataURL:将文件读取为DataURL(base64最为常见)
FileReader的状态
onabort 数据读取中断
onerror 数据读取出错
onloadstart 开始读取数据
onprogress 读取中
onload 读取成功时触发
onloadend 数据读取完成,无论成功失败都触发
在各种方法中,this.result指向读取的文件数据
4.本功能核心代码如下:
<input type="file" accept="image/*" ref="file" onChange={ctr.onchange} multiple/> <script>
if(typeof FileReader == undefined&&new FileReader().readAsDataURL) {
alert("不支持filereader");
}else{
var img = document.createElement("img");
document.body.appendChild(img);
var reader = new FileReader();
input = document.getElementById("file");
var onchange = function(){
var files = input.files;
for(var k=0;k<files.length;k++){
if(!/image\/\w+/.test(files[k].type)){
console.log(files[k].name+"不是图像文件!");
}else{
//此处可加入文件上传的代码
console.log(files[k].name+"文件已上传")
}
}
reader.readAsDataURL(files[0]);
reader.onload = function(){
img.src = this.result;
}
}
input.onchange = onchange;
}
</script>
很简单的感觉吧^_^
5.手机浏览器能力测试结果:
用手边的做了下功能支持的能力测试,结果如下,还是很乐观的哦~
用html5文件api实现移动端图片上传&预览效果的更多相关文章
- Jquery图片上传预览效果
uploadPreview.js jQuery.fn.extend({ uploadPreview: function (opts) { var _self = this, _this = $(thi ...
- 使用iframe实现图片上传预览效果
原理:将图片上传的页面放在iframe中,这样就可以在iframe中将图片提交到服务器而不需要页面刷新,提交成功后用脚本实现主页面显示上传的图片. Default.aspx: <%@ Page ...
- JS实现图片上传预览效果:方法一
<script type="text/javascript"> //处理file input加载的图片文件 $(document).ready(function(e) ...
- input file图片上传预览效果
两种方法,方法一: js代码: //头像上传预览 $("#up").change(function() { var $file = $(this); var fileObj = $ ...
- ASP.NET工作笔记之一:图片上传预览及无刷新上传
转自:http://www.cnblogs.com/sibiyellow/archive/2012/04/27/jqueryformjs.html 最近项目里面涉及到无刷新上传图片的功能,其实也就是上 ...
- HTML5 图片上传预览
<!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="utf-8& ...
- FileReader()读取文件、图片上传预览
前言 FileReader 对象允许Web应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,使用 File 或 Blob 对象指定要读取的文件或数据. 其中File对象可以是来自用户 ...
- html,图片上传预览,input file获取文件等相关操作
input file常用方法: var obj=document.getElementById("upimage"); var file=obj.files[0];//获取文件数据 ...
- 移动端 js 实现图片上传 预览
方法一: <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv=&q ...
随机推荐
- Android商城开发系列(十二)—— 首页推荐布局实现
首页新品推荐的布局效果如下图: 这块布局是使用LinearLayout和GridView去实现,新建recommend_item.xml,代码如下所示: <?xml version=" ...
- IOS 绘制图片水印(封装)
- (void)viewDidLoad { [super viewDidLoad]; // -1.加载图片 // UIImage *image = [UIImage imageNamed:@" ...
- hdu-2680 Choose the best route---dijkstra+反向存图或者建立超级源点
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2680 题目大意: 给你一个有向图,一个起点集合,一个终点,求最短路 解题思路: 1.自己多加一个超级 ...
- Opentsdb简介
1.OpenTSDB介绍 1.1.OpenTSDB是什么?主要用途是什么? 官方文档这样描述:OpenTSDB is a distributed, scalable Time Series Datab ...
- Python监控日志中经常访问的ip
一.需求:每分钟检查一次日志文件,如果这一分钟内同一个ip请求次数超过200次,加入黑名单 1.日志文件中,每一行的格式为:XXX.XXX.XXX.XXX - - [04/Jun/2017:05:25 ...
- angular路由学习笔记
文章目录 标签routerLink路由传递参数 url中get传值 定义路由 获取参数 配置动态路由 定义路由 获取参数 API js路由跳转 配置动态路由 定义路由 获取参数 get传值 定义路由 ...
- JoinQuant策略代码示例
总体回测前 ''' ================================================================================ 总体回测前 === ...
- CUDA编程时,线程块的处理方法
- cin对象的一些常用方法使用总结
>> 最初定义的是右移,当但是出现在 cin >>中的时候这个符号被重载了,变成了一个流操作,在用户通过键盘输入信息的时候,所有内容都会先直接存储在一个叫输入缓冲区的的地方,c ...
- 安装Tesseract
下载网站 https://digi.bib.uni-mannheim.de/tesseract/