一. FormData

利用FormData对象,我们可以通过JavaScript用一些键值对来模拟一系列表单控件,我们还可以使用XMLHttpRequest的send()方法来异步的提交这个”表单”.比起普通的ajax,使用FormData的最大优点就是我们可以异步上传一个二进制文件.

方法:

 1var formData = new FormData();
 2formData.append("k1", "v1"); 
 3formData.append("k1", "v2");
 4formData.get("k1"); 
 5formData.getAll("k1"); 
 6formData.set("k1", "1"); 
 7formData.has("k1"); 
 8formData.has("k2"); 
 9formData.delete("k1"); 

根据已有form表单初始化一个formData对象:

 1 var form = document.getElementById("myForm");
 2
 3var formData = new FormData(form);
 4
 5var name = formData.get("name"); 
 6var psw = formData.get("pw"); 
 7
 8formData.append("token","kshdfiwi3rh"); 

发送一个二进制数据流:

 1var content = '<a id="a"><b id="b">hey!</b></a>'; 
 2var blob = new Blob([content], { type: "text/xml"});
 3formData.append("file", blob);
 4axios.post('http://demo.api.com/doSomething', formData,
 5    {
 6        headers: {
 7            'Content-Type': 'multipart/form-data'
 8       }
 9   }
10) 

二. Blob

一个Blob对象就是一个包含有只读原始数据的类文件对象。Blob对象中的数据并不一定得是JavaScript中的原生形式。File接口基于Blob,继承了Blob的功能,并且扩展支持了用户计算机上的本地文件。

Blob对象可以看做是存放二进制数据的容器,但要读取里面的二进制数据,需要用FileReader;此外还可以通过Blob设置二进制数据的MIME类型。

 1 var blob = new Blob(dataArr:Array<any>, opt:{type:string}); 
  1. 创建一个装填DOMString对象的Blob对象
 1var s = '<div>hello</div>'
 2var blobObj = new Blob([s], {type: 'text/xml'}) 
  1. 创建一个装填ArrayBuffer对象的Blob对象
 1var abf = new ArrayBuffer(8)
 2var blobOjb = new Blob([abf], {type: 'text/plain'}) 
  1. Blob.slice()
    此方法返回一个新的Blob对象,包含了原Blob对象中指定范围内的数据,利用此发放可以实现大文件的分片上传
 1 Blob.slice(start:number, end:number, contentType:string) 
  1. Canvas.toBlob()
    canvas转为blob对象
  2. 实现url下载文件
    window.URL对象可以为Blob对象生成一个网络地址,结合a标签的download属性,可以实现点击url下载文件
 1function createDownload(fileName, content){
 2    var blob = new Blob([content]);
 3    var link = document.createElement("a");
 4    link.download = fileName;
 5    link.href = URL.createObjectURL(blob); 
 6    link.click()
 7} 

三. File

File是Blob的子类,比blob主要多出一个name的属性。

我们常用的文件选择标签元素就拥有一个files属性,这个files就是File类型

 1var input = document.querySelector('input[type=file]');
 2console.log(input.files) 

四. URL

除了可以使用base64字符串作为内容的DataURI将一个文件嵌入到另外一个文档里,还可以使用URL对象。URL对象用于生成指向File对象或Blob对象的URL

实例属性:

 1var url = new URL(location.href)
 2url.href 
 3url.protocol 
 4url.host 
 5url.hostname 
 6url.port 
 7url.pathname 
 8url.search 
 9url.hash 
10url.username 
11url.password 
12url.origin 
13url.searchParams 

静态方法:

  • URL.createObjectURL()
    该方法会创建一个 DOMString,其中包含一个表示参数中给出的对象的URL。这个 URL 的生命周期和创建它的窗口中的 document 绑定。这个新的URL 对象表示指定的 File 对象或 Blob 对象。
 1var objectURL = URL.createObjectURL(blob); 

blob是用来创建 URL 的 File 对象或者 Blob 对象​

  • URL.revokeObjectURL()
    该方法用来释放一个之前通过调用 URL.createObjectURL() 创建的已经存在的 URL 对象。当你结束使用某个 URL 对象时,应该通过调用这个方法来让浏览器知道不再需要保持这个文件的引用了。
 1window.URL.revokeObjectURL(objectURL); 

objectURL是一个 DOMString,表示通过调用 URL.createObjectURL() 方法产生的 URL 对象

五. URLSearchParams

URLSearchParams 接口定义了一些实用的方法来处理 URL 的查询字符串。
方法:

  • URLSearchParams.append() 插入一个指定的键/值对作为新的搜索参数。
  • URLSearchParams.delete() 从搜索参数列表里删除指定的搜索参数及其对应的值。
  • URLSearchParams.entries() 返回一个iterator可以遍历所有键/值对的对象。
  • URLSearchParams.get() 获取指定搜索参数的第一个值。
  • URLSearchParams.getAll() 获取指定搜索参数的所有值,返回是一个数组。
  • URLSearchParams.has() 返回Boolean判断是否存在此搜索参数。
  • URLSearchParams.keys() 返回iterator此对象包含了键/值对的所有键名。
  • URLSearchParams.set() 设置一个搜索参数的新值,假如原来有多个值将删除其他所有的值。
  • URLSearchParams.sort() 按键名排序。
  • URLSearchParams.toString() 返回搜索参数组成的字符串,可直接使用在URL上。
  • URLSearchParams.values() 返回iterator此对象包含了键/值对的所有值。
    基本用法:
 1var paramsString = "https://www.baidu.com?topic=api&target=bank"
 2var searchParams = new URLSearchParams(paramsString);
 3
 4searchParams.has('topic') 
 5searchParams.get('topic') 
 6searchParams.get('target') 
 7searchParams.getAll('topic') 
 8
 9searchParams.get('foo') 
10searchParams.set('foo', 2);
11searchParams.get('foo') 
12
13searchParams.append('topic', 'webdev');
14searchParams.toString() 
15
16searchParams.append('foo', 3);
17searchParams.getAll('foo') 
18
19searchParams.delete('topic');
20searchParams.toString() 

在一些场景里使用axios发送数据时若需要以application/x-www-form-urlencoded格式发送数据,在浏览器端可以用URLSearchParams的实例当作POST数据发送,所有数据都会URL编码。(请注意,由于URLSearchParams支持性不好,可以使用polyfill来转换,可以在入口文件引入

 1import 'url-search-params-polyfill'; 

在node环境里可以使用querystring模块进行编码

 1var querystring = require('querystring');
 2axios.post('http://something.com/', querystring.stringify({ foo: 'bar' }); 

DOM 的 a 元素节点的 searchParams 属性,就是一个 URLSearchParams 实例。

 1var a = document.createElement('a');
 2a.href = 'https://example.com?filter=api';
 3a.searchParams.get('filter') 

URLSearchParams 还可以与 URL 接口结合使用:

 1var url = new URL(location);
 2var foo = url.searchParams.get('foo') || 'somedefault'; 

六. FileReader

我们知道Blob对象只是二进制数据的容器,本身并不能操作二进制,FileReader对象就是专门操作二进制数据的,FileReader主要用于将文件内容读入内存,通过一系列异步接口,可以在主线程中访问本地文件。

创建实例:

 1var reader = new FileReader(); 

方法(入参都是FileBlob对象)

  • reader.abort() 终止文件读取操作
  • reader.readAsArrayBuffer(file) 异步按字节读取文件内容,结果用ArrayBuffer对象表示
  • reader.readAsBinaryString(file) 异步按字节读取文件内容,结果为文件的二进制串
    reader.readAsDataURL(file) 异步读取文件内容,结果用data:url(即Base64格式)的字符串形式表示
  • reader.readAsText(file, encoding) 异步按字符读取文件内容,结果用字符串形式表示

事件名称

  • onabort 当读取操作被中止时调用
  • onerror 当读取操作发生错误时调用
  • onload 当读取操作成功完成时调用
  • onloadend 当读取操作完成时调用,不管是成功还是失败
  • onloadstart 当读取操作将要开始之前调用
  • onprogress 在读取数据过程中周期性调用

它们在实际场景中的一些应用

  1. 上传图片后直接显示出来,而不用先经过后台
 1var input  = document.getElementById("file"); 
 2input.onchange = function(){
 3    var file = this.files[0];
 4    if(!!file){
 5        var reader = new FileReader();
 6        reader.readAsDataURL(file);
 7        reader.onload = function(){
 8            
 9           document.getElementById("file_img").src = reader.result 
10           console.log(reader.result);
11        }
12    }
13} 
  1. 图片转二进制Blob
    在实际文件上传中,将用户选择的图片读取为ArrayBuffer并保存到新的Blob对象中,二进制的方式传参比直接传图片效率更高)
 1input.addEventListener('change', function() {
 2  var file = this.files[0],
 3      fr = new FileReader(),
 4      blob;
 5  fr.onload = function() {
 6      blob = new Blob([this.result]);
 7      var formdata = new FormData()
 8      formdata.append('file', blob)
 9  };
10  fr.readAsArrayBuffer(file)
11}); 
  1. 图片Image转Base64
 1function getImgToBase64(url,callback){
 2    var canvas = document.createElement('canvas')
 3    var ctx = canvas.getContext('2d')
 4    var img = new Image
 5    img.crossOrigin = 'Anonymous';
 6    img.onload = function(){
 7        canvas.height = img.height;
 8        canvas.width = img.width;
 9        ctx.drawImage(img,0,0);
10        var dataURL = canvas.toDataURL('image/png'); 
11        callback(dataURL);
12        canvas = null;
13    };
14    img.src = url;
15} 
  1. Base64转为BlobFile
 1function base64ToBlob(base64){
 2    var arr = base64.split(',')
 3    var mime = arr[0].match(/:(.*?);/)[1]
 4    var bytes = atob(arr[1])      
 5    var n = bytes.length
 6    var u8arr = new Uint8Array(n)
 7    while(n--){
 8        u8arr[n]=bytes.charCodeAt(n);   
 9    }
10    return new Blob([u8arr], {type: mime})
11    
12
13   
14    var formdata = new FormData()
15    formdata.append('file', new Blob([u8arr], {type: mime}))
16    xhr.send(formdata)
17} 

最后编辑于

:2019.01.29 16:37:03

更多精彩内容,就在简书APP

“小礼物走一走,来简书关注我”

还没有人赞赏,支持一下

 

总资产18共写了8315字获得50个赞共22个粉丝

  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解…

    沈念sama阅读 145,047评论 1赞 306

  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都…

  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些…

  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不…

  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我…

    茶点故事阅读 49,312评论 1赞 262

  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一…

  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决…

  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我…

  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经…

  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日…

    茶点故事阅读 29,435评论 2赞 218

  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。…

    茶点故事阅读 30,790评论 1赞 232

  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带…

  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境…

    茶点故事阅读 31,734评论 3赞 214

  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日…

  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响…

  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还…

  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚…

    茶点故事阅读 33,875评论 2赞 238

被以下专题收入,发现更多相似内容

推荐阅读更多精彩内容

  • simplify the life HTML5 File API — 让前端操作文件变的可能 前言 在 HTML5…

    我是强强阅读 3,193评论 0赞 1

  • 原文:https://blog.csdn.net/mr_wuch/article/details/70141674

    R_X阅读 792评论 1赞 11

  • 简介 HTML5 终于为我们提供了一种通过 File API 规范与本地文件交互的标准方式。为了举例说明其功能,可…

  • 「养男养女都一样,看的是眼缘。」 母狗会来大姨妈呀,收拾起来挺麻烦的。就养一个小男孩吧,遂让May约了狗主人下午2…

    吉米秀阅读 207评论 0赞 1

  • 2018.08.04 子木分享的: 研究他人可以成就智慧,研究自己可以得到开悟。 @UP子木子木,很喜欢你今天分享…

个人笔记记录 2021 ~ 2025