真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

js中的Blob對象類型解析

今天小編給大家分享的是js中的Blob對象類型解析,很多人都不太了解,今天小編為了讓大家更加了解js中的Blob對象類型,所以給大家總結(jié)了以下內(nèi)容,一起往下看吧。一定會有所收獲的哦。

創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),岳麓企業(yè)網(wǎng)站建設(shè),岳麓品牌網(wǎng)站建設(shè),網(wǎng)站定制,岳麓網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,岳麓網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

js中的Blob對象類型解析

構(gòu)建一個(gè)Blob對象通常有三種方式:

1、通過Blob對象的構(gòu)造函數(shù)來構(gòu)建。

2、從已有的Blob對象調(diào)用slice接口切出一個(gè)新的Blob對象。

3、canvas API toBlob方法,把當(dāng)前繪制信息轉(zhuǎn)為一個(gè)Blob對象。下面只看第一種的實(shí)現(xiàn):

用法:新方法創(chuàng)建Blob 對象(構(gòu)造函數(shù)來構(gòu)建)

var blob = new Blob(array[optional], options[optional]);

構(gòu)造函數(shù),接受兩個(gè)參數(shù)

第一個(gè)參數(shù):為一個(gè)數(shù)據(jù)序列,可以是任意格式的值,例如,任意數(shù)量的字符串,Blobs 以及 ArrayBuffers。

第二個(gè)參數(shù):用于指定將要放入Blob中的數(shù)據(jù)的類型(MIME)(后端可以通過枚舉MimeType,獲取對應(yīng)類型:

MimeType mimeType = MimeType.toEnum(file.getContentType());)。
 

Blob對象的基本屬性:

size :Blob對象包含的字節(jié)數(shù)。(只讀)

type : Blob對象包含的數(shù)據(jù)類型MIME,如果類型未知?jiǎng)t返回空字符串。

原生對象構(gòu)建Blob

提示出錯(cuò):

Uncaught TypeError: Failed to construct ‘Blob': The 1st argument is neither an array, nor does it have indexed properties.

原因在于Blob構(gòu)造函數(shù)要求第一個(gè)參數(shù)必須是數(shù)組,而這里第一個(gè)參數(shù)既不是一個(gè)數(shù)組,也沒有可索引的屬性。既然這里提到了對象的可索引屬性,讓我聯(lián)想到了類數(shù)組的概念,而Arguments就是一個(gè)很好的例子。來試一試:

可以看到即使是類數(shù)組對象,而數(shù)組元素類型是Number也能得出正確的結(jié)論,猜想大概是由于構(gòu)造函數(shù)內(nèi)部把Number轉(zhuǎn)化為String的緣故吧!

再來試一試其他的參數(shù)類型:

window.onload = function() {
 var arg = {hello: "2016"};
 var blob = new Blob([JSON.stringify(arg, null, "\t")], {type: "application/json"});
 console.log(blob.type);//application/json
 console.log(blob.size);//20
}

blob.type等于application/json沒問題。arg轉(zhuǎn)為字符串后的長度為16加上制表符\t的寬度4個(gè)字節(jié)等于20。

Blob對象的基本方法:

大文件分割 (slice() 方法),slice方法與數(shù)組的slice類似。

Blob.slice([start, [end, [content-type]]])

slice() 方法接受三個(gè)參數(shù),起始偏移量,結(jié)束偏移量,還有可選的 mime 類型。如果 mime 類型,沒有設(shè)置,那么新的 Blob 對象的 mime 類型和父級一樣。

當(dāng)要上傳大文件的時(shí)候,此方法非常有用,可以將大文件分割分段,然后各自上傳,因?yàn)榉指钪蟮?Blob 對象和原始的是獨(dú)立存在的。

不過目前瀏覽器實(shí)現(xiàn)此方法還沒有統(tǒng)一,火狐使用的是 mozSlice() ,Chrome 使用的是 webkitSlice() ,其他瀏覽器則正常的方式 slice()

可以寫一個(gè)兼容各瀏覽器的方法:

 function sliceBlob(blob, start, end, type) {
 type = type || blob.type;
 if (blob.mozSlice) {
  return blob.mozSlice(start, end, type);
 } else if (blob.webkitSlice) {
  return blob.webkitSlice(start, end type);
 } else {
  throw new Error("This doesn't work!");
 }
 }

利用Blob顯示縮略圖

var input = document.createElement("input");
input.type = "file";
input.accept = "image/*";
input.multiple = true;
input.style.display = "none";
document.body.appendChild(input);

var fileSelect = document.createElement("a");
fileSelect.href = "#";
fileSelect.appendChild(document.createTextNode("Choose files"));
document.body.appendChild(fileSelect);

var imgList = document.createElement("div");
imgList.innerHTML = "

No file Selected!

" document.body.appendChild(imgList); input.addEventListener("change", function(e) { var files = this.files; if(!files.length) { return; } imgList.innerHTML = ""; var list = document.createElement("ul"); imgList.appendChild(list); for(var i = 0; i < files.length; i++) { var li = document.createElement("li"); list.appendChild(li); var img = document.createElement("img"); img.src = window.URL.createObjectURL(files[i]); img.height = 60; img.width = 60; img.onload = function() { window.URL.revokeObjectURL(this.src); } li.appendChild(img); var info = document.createElement("span"); info.innerHTML = files[i].name + ":" + files[i].size + " bytes"; li.appendChild(info); } }, false); fileSelect.addEventListener("click", function(e) { input.click(); e.preventDefault(); }, false);

由于File對象繼承自Blob,所以我們可以很方便的利用File對象加載本地系統(tǒng)圖片文件,并通過createObjectURL生成一個(gè)URL并加以顯示。

以上就是js中的Blob對象類型解析的詳細(xì)內(nèi)容了,看完之后是否有所收獲呢?如果想了解更多相關(guān)內(nèi)容,歡迎來創(chuàng)新互聯(lián)行業(yè)資訊!


網(wǎng)站欄目:js中的Blob對象類型解析
分享鏈接:http://weahome.cn/article/pcdjgc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部