博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
h5图片上传简易版(FileReader+FormData+ajax)
阅读量:5741 次
发布时间:2019-06-18

本文共 2690 字,大约阅读时间需要 8 分钟。

一、选择图片(input的file类型

1. input的file类型会渲染为一个按钮和一段文字。点击按钮可打开文件选择窗口;file类型的input会有files属性,保存着文件的相关信息。

2. input.files是一个数组,由传入的file对象组成。每个file对象包含以下属性:

lastModified:数值,表示最近一次修改时间的毫秒数;

lastModifiedDate:对象,表示最后一次修改时间的Date对象(高程中说是字符串,根据上图可看出应该为对象,为了层级清晰未对其展开,大家可自行查看,其可调用Date对象的有关方法,例如getDay方法);

name:本地文件系统中的文件名;

size:文件的字节大小;

type:字符串,文件的MIME类型;

weblitRelativePath:此处为空;当在input上加上webkitdirectory属性时,用户可选择文件夹,此时weblitRelativePath表示文件夹中文件的相对路径。比如:

二、读取图片数据 (FileReader对象)

FileReader  对象是一种异步文件读取机制,使用 File或 Blob对象指定要读取的文件或数据,结合input:file可以很方便的读取本地文件。

var reader = new FileReader();//创建一个FileReader实例reader.readAsDataURL(file);//调用fileReader对象的方法,将文件读取为DataURLreader.onload = function(){
//处理事件  console.log(this.result);//读取完成后,数据保存在对象的result属性中,打印结果如下:(截取部分结果)}

三、上传图片   ( formData对象 )

1. 用一些键值对来模拟一系列表单控件,以key与value形式组装成一个对象,FormData对象的操作方法,全部在原型中,自己本身没任何的属性及方法。

2. 异步上传二进制文件。

3. 属性不是直接挂载在你这个FormData实例上。可以通过它提供的迭代器,或者get方法去取值。

var formData=new FormData();//创建一个空对象实例formData.append('key',value);//向该对象添加字段console.log(formData.get("key")); // 打印key值对应的value值

4. formData操作

(1)获取值:通过formData.get(key)/getAll(key)来获取对应的value

(2)添加数据:通过formData.append(key, value)来添加数据,如果指定的key不存在则会新增一条数据,如果key存在,则添加到数据的末尾

(3)修改数据:通过formData.set(key, value)来设置修改数据,如果指定的key不存在则会新增一条,如果存在,则会修改对应的value值

(4)判断是否该数据:通过formData.has(key)来判断是否对应的key值

(5)删除数据:通过formData.delete(key),来删除数据

(6)遍历数据:通过formData.entries()来获取一个迭代器,然后遍历所有的数据

(7)发送数据:ajax异步请求

四、jQuery上传图片代码

var formdata;if (typeof FileReader === 'undefined') {
//检测浏览器对FileReader兼容性 showimg.innerHTML = "抱歉,你的浏览器不支持 FileReader"; imginput.setAttribute('disabled', 'disabled');} else { imginput.addEventListener('change', function() { var file = this.files[0]; console.log(file); if (!/image\/\w+/.test(file.type)) { alert("请确保文件为图像类型"); return false; } var reader = new FileReader();//创建一个FileReader实例       reader.readAsDataURL(file);//将文件内容进行base64编码后输出       //console.log(reader)        reader.onload = function(e) {           //console.log(this.result);//读取完成后,数据保存在对象的result属性中           $(showimg).append('');//将选中的图片显示在页面上 //alert('111');            formData=new FormData();           formData.append('file',file);           console.log(formData.getAll('file'));        }    }, false); }$.ajax({ url : url, type : 'post', dataType:"json", data:formData, cache: false, processData : false,// 告诉jQuery不要去处理发送的数据 contentType : false,// 告诉jQuery不要去设置Content-Type请求头 success : function(data, status, xhr) { //alert(1); }, error : function(xhr, errorType, error) { //alert(0); }});

 

转载于:https://www.cnblogs.com/wyp-AY/p/9281426.html

你可能感兴趣的文章
cof文件在C语言中怎么引入,COF文件擴展名: 它是什麼以及如何打開它?
查看>>
android imageview旋转动画,Android UI之ImageView实现图片旋转和缩放
查看>>
android屏幕录制功能,Android利用ADB进行屏幕录制
查看>>
gt240m x86 android,国产平板福音!INTEL ATOM x86_64位Xposed框架,Android5.1(lolipop)适用...
查看>>
android7.1自带壁纸,RK3399 Android7.1 修改壁纸
查看>>
android系统文件重命名文件格式,重命名下载后的文件系统文件中的PhoneGap的Android...
查看>>
Java入门系列-26-JDBC
查看>>
区块链教程Fabric1.0源代码分析Peer EndorserClient(Endorser客户端)
查看>>
Java Web之SpringMVC 进行参数绑定
查看>>
如何解决OutOfMemoryError
查看>>
喔趣获逾1.6亿元B轮融资,打造中国的Kronos+Recruit
查看>>
Heapster启动的进一步研究
查看>>
Sping 系列框架官方参考文档(全)
查看>>
迁移潮来袭!数十个项目宣布即将停止支持 Python 2
查看>>
阿里云K8S服务-数据盘扩容方案
查看>>
Java 11正式发布,这几个逆天新特性教你写出更牛逼的代码
查看>>
【Arduino基础教程】多线程入门
查看>>
阿里云服务器如何用发送邮件
查看>>
【WebAPI No.4】Swagger实现API文档功能
查看>>
PESCMS Ticket 客服工单系统 v1.2.6 发布
查看>>