亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

使用js在layui中實現上傳圖片壓縮

2019-11-19 11:19:08
字體:
來源:轉載
供稿:網友

一、關于js上傳圖片壓縮的方法,百度有很多種方法,這里我參考修改了一下

function photoCompress(file, w, objDiv) {var ready = new FileReader();/*開始讀取指定的Blob對象或File對象中的內容. 當讀取操作完成時,readyState屬性的值會成為DONE,如果設置了onloadend事件處理程序,則調用之.同時,result屬性中將包含一個data: URL格式的字符串以表示所讀取文件的內容.*/ready.readAsDataURL(file);ready.onload = function() {var re = this.result;canvasDataURL(re, w, objDiv);}};function canvasDataURL(path, obj, callback) {var img = new Image();img.src = path;img.onload = function() {var that = this;// 默認按比例壓縮var w = that.width,h = that.height,scale = w / h;w = obj.width || w;h = obj.height || (w / scale);var quality = 0.5; // 默認圖片質量為0.7//生成canvasvar canvas = document.createElement('canvas');var ctx = canvas.getContext('2d');// 創建屬性節點var anw = document.createAttribute("width");anw.nodeValue = w;var anh = document.createAttribute("height");anh.nodeValue = h;canvas.setAttributeNode(anw);canvas.setAttributeNode(anh);ctx.drawImage(that, 0, 0, w, h);// 圖像質量if(obj.quality && obj.quality <= 1 && obj.quality > 0) {quality = obj.quality;}// quality值越小,所繪制出的圖像越模糊var base64 = canvas.toDataURL('image/jpeg', quality);// 回調函數返回base64的值callback(base64);}}function convertBase64UrlToBlob(urlData) {var arr = urlData.split(','),mime = arr[0].match(/:(.*?);/)[1],bstr = atob(arr[1]),n = bstr.length,u8arr = new Uint8Array(n);while(n--) {u8arr[n] = bstr.charCodeAt(n);}return new Blob([u8arr], {type: mime});}

以上是壓縮圖片的方法,核心是將圖片放入canvas內,再用canvas.toDataURL方法進行壓縮,最后生成一個Blob對象。

注:因為牽扯到canvas,所以低版本瀏覽器應該是不支持的吧(有待考證)

二、圖片壓縮的方法有了,怎么使用呢?怎么上傳到后臺呢?往下看!

html部分:

<form action="file/uploadDoc" enctype="multipart/form-data" method="post" id="form"><input type="file" id="file" name="file" /><input type="submit" value="上傳" /></form>

js部分:

$("#file").change(function() {var formData = new formData("form");var file = this.files[0];photoCompress(file, {quality: 0.5,}, function(base64Codes) {var bl = convertBase64UrlToBlob(base64Codes);formData.set("file", bl, file.name);});});

當選擇文件以后,使用photoCompress方法對上傳的圖片進行壓縮,photoCompress方法的第二個參數還可以傳入長寬等參數,具體可以看photoCompress這個方法,quality是用來設置壓縮后圖片質量的,越小質量越差,表現出來就是圖片越模糊,但是相應的體積就越小。

最后使用formData.set(key,value,name)方法,將現有的name為file的表單元素的值改變。這個方法有三個參數,第一個是key值,也就是表單里對應的元素的name值(如果不存在會自行添加),第二個值是value值,第三個是選填的值,如果第二個值為blob對象或者file對象,則第三個值表示文件名。

當然,如果你不想用form表單提交,你也可以用ajax提交的方法:

html:   

<form enctype="multipart/form-data" method="post" id="form"><input type="file" id="file" name="file" /><input type="button" value="上傳" id="uploadBtn"/></form>

有些許的變化,form沒有了action,上傳的按鈕type改為了button

js部分給按鈕添加一個點擊事件,其他也沒有變化,不做過多贅述:

$("#uploadBtn").click(function () {var formData = new formData("form");$.ajax({type:"post",url:"",async:true,data:formData,success:function (data) {},error:function (e) {}});});

三、結合layui踩的一些坑,以及最終的解決方法。

先看html部分:

<button type="button" class="layui-btn" id="upImg">上傳圖片</button><div id="img_list"></div><input type="button" id = "btnHide" class="none">

就是這么簡單。為什么要再寫一個隱藏的按鈕,之后解釋。

js部分:

layui.use('upload', function() {var upload = layui.upload;var uploadInst = upload.render({elem: '#upImg',url: '/upload/',auto: false,bindAction: "#btnHide",choose: function(obj) {var files = obj.pushFile();var index, file, indexArr = [];for(index in files) {indexArr.push(index);};var iaLen = indexArr.length;file = files[indexArr[iaLen - 1]];for(var i = 0; i < iaLen - 1; i++) {delete files[indexArr[i]];}try {if(file.size > 200 * 1024) {delete files[index];photoCompress(file, {quality: 0.5,}, function(base64Codes) {var bl = convertBase64UrlToBlob(base64Codes);obj.resetFile(index, bl, file.name);$("#btnHide").trigger("click");});} else {$("#btnHide").trigger("click");}} catch(e) {$("#btnHide").trigger("click");}},done: function(res) {//這里把后臺返回的數據進行操作,展示上傳完成的圖片,具體數據格式參考layui的API},error: function() {}});});

原理:在選擇照片之后,獲取文件,轉換為blob對象,使用resetFile方法對文件列隊里的文件進行重新設置,然后再觸發上傳事件。

踩的坑:

1、resetFile這個方法是layui 2.3.0 新增的,所以首先要確保layui的版本是最新的。

2、我把auto設置為false,點擊btnHide時觸發上傳,我也試過自動上傳,自動上傳的話,這些操作的代碼就要寫在before方法中(具體看layui的API),然而我發現自動上傳修改文件列隊的方法總是在上傳成功之后才調用,這就導致實際上傳的圖片其實沒有壓縮,至于為什么是這個執行順序我隱約覺得是不是圖片轉碼,放入canvas的時候耽誤了……具體原因我不明白,所以我用手動上傳,確認修改了文件列隊,再手動觸發上傳。

3、關于文件列隊,多次上傳文件,文件列隊也就是obj.pushFile()返回的是多個文件的對象,而且這些文件對象的key還是一串隨機數……所以我的思路是上傳一次,就用delete方法刪除隊列中已上傳過的文件。至于為什么不直接全部清空,因為考慮到不需要壓縮的情況,如果全部清空,不壓縮,就沒有執行resetFile方法,文件列隊里就沒有文件,會報錯。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美中文在线观看国产| 亚洲国产成人爱av在线播放| 色综合91久久精品中文字幕| 欧美精品电影免费在线观看| 国产精品扒开腿做爽爽爽男男| 91黑丝高跟在线| 欧美风情在线观看| 中文日韩在线视频| 精品久久中文字幕久久av| 国产欧美日韩精品在线观看| 一个人看的www欧美| 欧美第一黄网免费网站| 97国产成人精品视频| www.久久撸.com| 91久久久久久国产精品| 日韩一级裸体免费视频| 91久久国产综合久久91精品网站| 亚洲天堂av在线播放| 国产精品永久在线| 国产精品久久综合av爱欲tv| 久久艳片www.17c.com| 日韩福利视频在线观看| 国产精品丝袜白浆摸在线| 成人av资源在线播放| 亚洲性视频网站| 俺也去精品视频在线观看| 综合国产在线观看| 国产午夜精品全部视频在线播放| 日韩在线中文视频| 国内自拍欧美激情| 九九热精品视频| 欧美人在线观看| 日韩有码在线视频| 国产成人综合精品| 色婷婷**av毛片一区| 久久成人人人人精品欧| 亚洲国产精品国自产拍av秋霞| 久久亚洲精品成人| 日产精品99久久久久久| 亚洲男人天堂2024| 日韩视频一区在线| 国产精品嫩草影院久久久| 91av在线免费观看| 北条麻妃一区二区在线观看| 日韩中文娱乐网| 亚洲永久在线观看| 中文日韩在线观看| 亚洲一区二区久久久久久| 亚洲欧美制服第一页| 伊人久久男人天堂| 国产精品久久9| 国产精品电影网站| 国产欧美一区二区三区在线看| 日韩欧美亚洲成人| 久久精品国产久精国产一老狼| 国产精品久久久久久久久久尿| 亚洲欧美中文另类| 亚洲国产欧美一区二区三区久久| 粉嫩av一区二区三区免费野| 欧美成人精品不卡视频在线观看| 精品国产一区二区三区四区在线观看| 欧美日韩亚洲国产一区| 欧美中文字幕在线| 在线电影av不卡网址| 久久精品电影一区二区| 92福利视频午夜1000合集在线观看| 亚洲人在线视频| 国产精品18久久久久久麻辣| 欧美激情视频在线观看| 国产精品三级久久久久久电影| 另类美女黄大片| 日本欧美一级片| 成人午夜在线视频一区| 日日骚久久av| 亚洲国模精品一区| 国语对白做受69| 国产亚洲一区精品| 色综合导航网站| 国产日韩在线亚洲字幕中文| 国产mv久久久| 成人性生交大片免费看小说| 国产一区二区黄| 亚洲国产天堂久久综合| 亚洲午夜精品久久久久久久久久久久| 97婷婷大伊香蕉精品视频| 欧美最顶级丰满的aⅴ艳星| 韩国欧美亚洲国产| 亚洲色图35p| 日韩av在线天堂网| 欧美尺度大的性做爰视频| 日韩欧美在线第一页| 日韩精品免费一线在线观看| 成人免费视频a| 亚洲曰本av电影| 91精品国产自产在线观看永久| 欧美成人免费在线视频| 欧美亚洲视频在线看网址| 欧美伊久线香蕉线新在线| 91po在线观看91精品国产性色| 91国产视频在线| 中文字幕少妇一区二区三区| www.日韩不卡电影av| 国产精品黄色影片导航在线观看| 97av在线播放| 久久五月情影视| 亚洲欧洲av一区二区| 蜜臀久久99精品久久久无需会员| 91老司机精品视频| 国产在线观看91精品一区| 亚洲激情电影中文字幕| 久久精品亚洲精品| 国产精品成人观看视频国产奇米| 97色在线视频观看| 久久免费视频网| 国产精品久久久久久av福利软件| 亚洲国产精彩中文乱码av| 亚洲一区二区久久| 亚洲美女在线观看| 欧美激情在线播放| 91精品国产沙发| 国产在线视频一区| 欧美视频在线观看免费| 亚洲性猛交xxxxwww| 久久视频免费观看| 亚洲女同精品视频| 国产91热爆ts人妖在线| 亚洲精品xxxx| 欧美日韩亚洲视频一区| 亚洲色图色老头| 亚洲永久免费观看| 欧美亚洲视频在线观看| 国产精品美女av| 亚洲第一av网站| 欧美精品在线视频观看| 欧美亚洲另类激情另类| 韩国日本不卡在线| 国产欧美精品xxxx另类| 九九热精品视频| 日韩a**中文字幕| 国产在线观看精品一区二区三区| 亚洲欧美自拍一区| 另类少妇人与禽zozz0性伦| 自拍偷拍亚洲欧美| 91精品啪在线观看麻豆免费| 日韩免费视频在线观看| 国产在线精品自拍| 欧美性生活大片免费观看网址| 欧美夫妻性生活xx| 亚洲午夜av电影| 亚洲精品一区二区网址| 国产91在线播放精品91| 91在线视频九色| 亚洲欧美在线免费| 国外视频精品毛片| 亚洲美女av网站| 日韩经典一区二区三区| 深夜精品寂寞黄网站在线观看| 久久久久中文字幕2018| 亚洲一级黄色av| 国产精品视频1区| 91免费综合在线| 日本欧美黄网站| 精品久久久久久久久久久久久久| 性亚洲最疯狂xxxx高清|