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

首頁 > 開發 > JS > 正文

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

2024-05-06 16:52:23
字體:
來源:轉載
供稿:網友

一、關于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方法,文件列隊里就沒有文件,會報錯。

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


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
有码中文亚洲精品| 欧美夜福利tv在线| 久久精品2019中文字幕| 精品偷拍一区二区三区在线看| 热re91久久精品国99热蜜臀| 亚洲欧美综合v| 成人h视频在线观看播放| 国产精品一区二区在线| 久久久极品av| 欧美亚洲另类视频| 久久人体大胆视频| 欧美日韩中文字幕在线| 成人激情综合网| 欧美日韩国产成人高清视频| 色樱桃影院亚洲精品影院| 国产精品成人va在线观看| 国产精品美女网站| 国产精品色婷婷视频| 九九精品在线观看| 日韩小视频在线观看| 狠狠久久亚洲欧美专区| 日韩经典中文字幕| 中文字幕在线观看亚洲| 亚洲精品国产综合久久| 疯狂做受xxxx欧美肥白少妇| 欧美日韩一区二区精品| 性色av一区二区三区免费| 91国内产香蕉| 亚洲老板91色精品久久| 国产91精品久久久久久| 国产精品欧美日韩一区二区| 欧美精品第一页在线播放| 欧美一区在线直播| 国产精品女主播视频| 久久久久亚洲精品国产| 日韩久久免费视频| 在线播放日韩专区| 韩国三级电影久久久久久| 亚洲999一在线观看www| 国产亚洲综合久久| 午夜精品理论片| 亚洲图中文字幕| 亚洲高清一区二| 欧美成年人视频网站欧美| 国精产品一区一区三区有限在线| 最近2019年好看中文字幕视频| 97在线视频免费播放| 成人h猎奇视频网站| 亚洲男人第一网站| 一区二区三区www| 日韩电影在线观看免费| 欧美精品videosex牲欧美| 久久亚洲精品中文字幕冲田杏梨| 国产精品露脸av在线| 久久天天躁狠狠躁夜夜躁| 欧美日韩精品在线观看| 成人乱色短篇合集| 日韩人体视频一二区| 欧美亚洲视频在线观看| 欧美日韩美女在线| 国产97在线观看| 国产亚洲欧美视频| 精品露脸国产偷人在视频| 91精品视频播放| 欧洲永久精品大片ww免费漫画| 亚洲一区二区三区xxx视频| 国产成人精品优优av| 韩国三级日本三级少妇99| 亚洲片在线资源| 国产在线观看91精品一区| 欧美成人精品激情在线观看| 欧美在线视频在线播放完整版免费观看| 国产精品福利网站| 国产精品福利在线观看网址| 色阁综合伊人av| 欧美性20hd另类| 丁香五六月婷婷久久激情| 中文字幕自拍vr一区二区三区| 国产suv精品一区二区三区88区| 国语自产精品视频在线看一大j8| 久久伊人91精品综合网站| 亚洲国产精品热久久| 日韩精品在线视频观看| 欧美日韩精品二区| 动漫精品一区二区| 国产成人精品电影久久久| 国产亚洲欧美另类中文| 国产v综合v亚洲欧美久久| 欧美色另类天堂2015| 国产欧美一区二区三区久久| 日韩免费在线播放| 亚洲国产精品久久精品怡红院| 国内外成人免费激情在线视频| 国产视频精品免费播放| 欧美精品一区三区| 亚洲色图50p| 欧美性生交大片免网| 热门国产精品亚洲第一区在线| 欧美理论在线观看| 亚洲aaa激情| 日韩激情av在线播放| 91综合免费在线| 国产香蕉精品视频一区二区三区| 亚洲少妇激情视频| 国产欧美日韩亚洲精品| 日韩麻豆第一页| 国产欧美一区二区三区视频| 国产精品三级久久久久久电影| 激情亚洲一区二区三区四区| 高清欧美性猛交xxxx| 欧美伊久线香蕉线新在线| 97成人在线视频| 国产精品成人v| 欧美激情免费观看| 亚洲国产精品成人va在线观看| 国产精品久久久久久网站| 国内精品久久久久伊人av| 亚洲高清福利视频| 精品综合久久久久久97| 在线电影中文日韩| 国产精品免费一区豆花| 国产精品精品视频一区二区三区| 在线国产精品视频| www.美女亚洲精品| 97精品国产97久久久久久免费| 欧美亚洲日本网站| 欧美精品videos| 国产精品视频自拍| 国产91精品久久久久久久| 欧美成人高清视频| 91成人天堂久久成人| 欧美尺度大的性做爰视频| 美女国内精品自产拍在线播放| 亚洲视频在线免费观看| 久久久久亚洲精品国产| 色先锋久久影院av| 日韩中文在线不卡| 久久人人爽人人爽人人片av高请| 久久久久免费精品国产| 中国日韩欧美久久久久久久久| 久久久久免费精品国产| 欧美性xxxxx极品| 国产精品网址在线| 国外成人免费在线播放| 97久久伊人激情网| 波霸ol色综合久久| 成人午夜高潮视频| 久久久精品久久久| 欧美亚洲国产日本| 97成人在线视频| 日韩有码片在线观看| 日韩在线观看免费全| 中文字幕久热精品在线视频| 91精品国产综合久久香蕉的用户体验| 中文字幕亚洲无线码在线一区| 久久视频在线视频| 亚洲欧美三级在线| 亚洲欧美精品suv| 亚洲午夜未删减在线观看| 中文字幕亚洲欧美日韩高清| 亚洲一区中文字幕| 国产欧美日韩91| 国产精品黄色影片导航在线观看| 欧美激情免费在线|