电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

JS 圖片壓縮原理與實現方法詳解

瀏覽:105日期:2024-05-10 17:35:20

本文實例講述了JS 圖片壓縮原理與實現方法。分享給大家供大家參考,具體如下:

前言

說起圖片壓縮,大家想到的或者平時用到的很多工具都可以實現,例如,客戶端類的有圖片壓縮工具 PPDuck3, JS 實現類的有插件 compression.js ,亦或是在線處理類的 OSS 上傳,文件上傳后,在訪問文件時中也有圖片的壓縮配置選項,不過,能不能自己擼一套 JS 實現的圖片壓縮代碼呢?當然可以,那我們先來理一下思路。

壓縮思路

涉及到 JS 的圖片壓縮,我的想法是需要用到 Canvas 的繪圖能力,通過調整圖片的分辨率或者繪圖質量來達到圖片壓縮的效果,實現思路如下:

獲取上傳 Input 中的圖片對象 File 將圖片轉換成 base64 格式 base64 編碼的圖片通過 Canvas 轉換壓縮,這里會用到的 Canvas 的 drawImage 以及 toDataURL 這兩個 Api,一個調節圖片的分辨率的,一個是調節圖片壓縮質量并且輸出的,后續會有詳細介紹 轉換后的圖片生成對應的新圖片,然后輸出優缺點介紹

不過 Canvas 壓縮的方式也有著自己的優缺點:

優點:實現簡單,參數可以配置化,自定義圖片的尺寸,指定區域裁剪等等。 缺點:只有 jpeg 、webp 支持原圖尺寸下圖片質量的調整來達到壓縮圖片的效果,其他圖片格式,僅能通過調節尺寸來實現代碼實現

<template> <div class='container'> <input type='file' @change='compress' /> <a :download='fileName' :href='http://www.hdgsjgj.cn/bcjs/compressImg' rel='external nofollow' >普通下載</a> <button @click='downloadImg'>兼容 IE 下載</button> <div> <img :src='http://www.hdgsjgj.cn/bcjs/compressImg' /> </div> </div></template><script>export default { name: ’compress’, data: function() { return { compressImg: null, fileName: null, }; }, components: {}, methods: { compress() { // 獲取文件對象 const fileObj = document.querySelector(’#input-img’).files[0]; // 獲取文件名稱,后續下載重命名 this.fileName = `${new Date().getTime()}-${fileObj.name}`; // 獲取文件后綴名 const fileNames = fileObj.name.split(’.’); const type = fileNames[fileNames.length-1]; // 壓縮圖片 this.handleCompressImage(fileObj, type); }, handleCompressImage(img, type) { const vm = this; let reader = new FileReader(); // 讀取文件 reader.readAsDataURL(img); reader.onload = function(e) { let image = new Image(); //新建一個img標簽 image.src = e.target.result; image.onload = function() { let canvas = document.createElement(’canvas’); let context = canvas.getContext(’2d’); // 定義 canvas 大小,也就是壓縮后下載的圖片大小 let imageWidth = image.width; //壓縮后圖片的大小 let imageHeight = image.height; canvas.width = imageWidth; canvas.height = imageHeight; // 圖片不壓縮,全部加載展示 context.drawImage(image, 0, 0); // 圖片按壓縮尺寸載入 // let imageWidth = 500; //壓縮后圖片的大小 // let imageHeight = 200; // context.drawImage(image, 0, 0, 500, 200); // 圖片去截取指定位置載入 // context.drawImage(image,100, 100, 100, 100, 0, 0, imageWidth, imageHeight); vm.compressImg = canvas.toDataURL(`image/${type}`); }; }; }, // base64 圖片轉 blob 后下載 downloadImg() { let parts = this.compressImg.split(’;base64,’); let contentType = parts[0].split(’:’)[1]; let raw = window.atob(parts[1]); let rawLength = raw.length; let uInt8Array = new Uint8Array(rawLength); for(let i = 0; i < rawLength; ++i) { uInt8Array[i] = raw.charCodeAt(i); } const blob = new Blob([uInt8Array], {type: contentType}); this.compressImg = URL.createObjectURL(blob); if (window.navigator.msSaveOrOpenBlob) { // 兼容 ie 的下載方式 window.navigator.msSaveOrOpenBlob(blob, this.fileName); }else{ const a = document.createElement(’a’); a.href = this.compressImg; a.setAttribute(’download’, this.fileName); a.click(); } }, }};</script>

上面的代碼是可以直接拿來看效果的,不喜歡用 Vue 的也可以把代碼稍微調整一下,下面開始具體分解一下代碼的實現思路

Input 上傳 File 處理

將 File 對象通過 FileReader 的 readAsDataURL 方法轉換為URL格式的字符串(base64編碼)

const fileObj = document.querySelector(’#input-img’).files[0];let reader = new FileReader();// 讀取文件reader.readAsDataURL(fileObj);Canvas 處理 File 對象

建立一個 Image 對象,一個 canvas 畫布,設定自己想要下載的圖片尺寸,調用 drawImage 方法在 canvas 中繪制上傳的圖片

let image = new Image(); //新建一個img標簽image.src = e.target.result;let canvas = document.createElement(’canvas’);let context = canvas.getContext(’2d’);context.drawImage(image, 0, 0);Api 解析:drawImage

context.drawImage(img, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight);

img

就是圖片對象,可以是頁面上獲取的 DOM 對象,也可以是虛擬 DOM 中的圖片對象。

JS 圖片壓縮原理與實現方法詳解

dx , dy , dWidth , dHeight

表示在 canvas 畫布上規劃出一片區域用來放置圖片,dx, dy 為繪圖位置在 Canvas 元素的 X 軸、Y 軸坐標,dWidth, dHeight 指在 Canvas 元素上繪制圖像的寬度和高度(如果不說明, 在繪制時圖片的寬度和高度不會縮放)。

sx , sy , swidth , sheight

這 4 個參數是用來裁剪源圖片的,表示圖片在 canvas 畫布上顯示的大小和位置。sx,sy 表示在源圖片上裁剪位置的 X 軸、Y 軸坐標,然后以 swidth,sheight 尺寸來選擇一個區域范圍,裁剪出來的圖片作為最終在 Canvas 上顯示的圖片內容( swidth,sheight 不說明的情況下,整個矩形(裁剪)從坐標的 sx 和 sy 開始,到圖片的右下角結束)。

以下為圖片繪制的實例:

context.drawImage(image, 0, 0, 100, 100);context.drawImage(image, 300, 300, 200, 200);context.drawImage(image, 0, 100, 150, 150, 300, 0, 150, 150);

JS 圖片壓縮原理與實現方法詳解

Api 中奇怪之處在于,sx,sy,swidth,sheight 為選填參數,但位置在 dx, dy, dWidth, dHeight 之前。

Canvas 輸出圖片

調用 canvas 的 toDataURL 方法可以輸出 base64 格式的圖片。

canvas.toDataURL(`image/${type}`);Api 解析:toDataURL

canvas.toDataURL(type, encoderOptions);

type 可選

圖片格式,默認為 image/png。

encoderOptions 可選

在指定圖片格式為 image/jpeg 或 image/webp的情況下,可以從 0 到 1 的區間內選擇圖片的質量。如果超出取值范圍,將會使用默認值 0.92。其他參數會被忽略。

a 標簽的下載

調用 <a> 標簽的 download 屬性,即可完成圖片的下載。

Api 解析:download

// href 下載必填<a download='filename' href='http://www.hdgsjgj.cn/bcjs/href' rel='external nofollow' > 下載 </a>

filename

選填,規定作為文件名來使用的文本。

href

文件的下載地址。

非主流瀏覽器下載處理

到此可以解決 Chroma 、 Firefox 和 Safari(自測支持) 瀏覽器的下載功能,因為 IE 等瀏覽器不支持 download 屬性,所以需要進行其他方式的下載,也就有了代碼中的后續內容

// base64 圖片轉 blob 后下載downloadImg() { let parts = this.compressImg.split(’;base64,’); let contentType = parts[0].split(’:’)[1]; let raw = window.atob(parts[1]); let rawLength = raw.length; let uInt8Array = new Uint8Array(rawLength); for(let i = 0; i < rawLength; ++i) { uInt8Array[i] = raw.charCodeAt(i); } const blob = new Blob([uInt8Array], {type: contentType}); this.compressImg = URL.createObjectURL(blob); if (window.navigator.msSaveOrOpenBlob) { // 兼容 ie 的下載方式 window.navigator.msSaveOrOpenBlob(blob, this.fileName); }else{ const a = document.createElement(’a’); a.href = this.compressImg; a.setAttribute(’download’, this.fileName); a.click(); }} 將之前 canvas 生成的 base64 數據拆分后,通過 atob 方法解碼 將解碼后的數據轉換成 Uint8Array 格式的無符號整形數組 轉換后的數組來生成一個 Blob 數據對象,通過 URL.createObjectURL(blob) 來生成一個臨時的 DOM 對象 之后 IE 類瀏覽器可以調用 window.navigator.msSaveOrOpenBlob 方法來執行下載,其他瀏覽器也可以繼續通過 <a> 標簽的 download 屬性來進行下載Api 解析:atob

base-64 解碼使用方法是 atob()。

window.atob(encodedStr)

encodedStr

必需,是一個通過 btoa() 方法編碼的字符串,btoa()是 base64 編碼的使用方法。

Api 解析:Uint8Array

new Uint8Array(length)

length

創建初始化為 0 的,包含 length 個元素的無符號整型數組。

Api 解析: Blob

Blob 對象表示一個不可變、原始數據的類文件對象。

// 構造函數允許通過其它對象創建 Blob 對象new Blob([obj],{type:createType})

obj

字符串內容

createType

要構造的類型

兼容性 IE 10 以上

Api 解析:createObjectURL

靜態方法會創建一個 DOMString。

objectURL = URL.createObjectURL(object);

object

用于創建 URL 的 File 對象、Blob 對象或者 MediaSource 對象。

Api 解析: window.navigator

// 官方已不建議使用的文件下載方式,僅針對 ie 且兼容性 10 以上// msSaveBlob 僅提供下載// msSaveOrOpenBlob 支持下載和打開window.navigator.msSaveOrOpenBlob(blob, fileName);

blob

要下載的 blob 對象

fileName

下載后命名的文件名稱。

總結

本文僅針對圖片壓縮介紹了一些思路,簡單的使用場景可能如下介紹,當然也會引申出來更多的使用場景,這些還有待大家一起挖掘。

上傳存儲圖片如果需要對文件大小格式有要求的,可以統一壓縮處理圖片 前臺頁面想要編輯圖片,可以在 Canvas 處理圖片的時候,加一些其他邏輯,例如添加文字,剪裁,拼圖等等操作

當然溫馨提示:因部分接口有 IE 兼容性問題,IE 瀏覽器方面,僅能支持 IE10 以上版本進行下載。

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript圖片操作技巧大全》、《JavaScript切換特效與技巧總結》、《JavaScript運動效果與技巧匯總》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 重庆网站建设,重庆网站设计,重庆网站制作,重庆seo,重庆做网站,重庆seo,重庆公众号运营,重庆小程序开发 | 免费个人pos机申请办理-移动pos机刷卡-聚合收款码办理 | 北京印刷厂_北京印刷_北京印刷公司_北京印刷厂家_北京东爵盛世印刷有限公司 | 防腐木批发价格_深圳_惠州_东莞防腐木厂家_森源(深圳)防腐木有限公司 | 直齿驱动-新型回转驱动和回转支承解决方案提供商-不二传动 | 彭世修脚_修脚加盟_彭世修脚加盟_彭世足疗加盟_足疗加盟连锁_彭世修脚技术培训_彭世足疗 | 楼承板-钢筋楼承板-闭口楼承板-无锡优贝斯楼承板厂 | 福州时代广告制作装饰有限公司-福州广告公司广告牌制作,福州展厅文化墙广告设计, | 上海软件开发-上海软件公司-软件外包-企业软件定制开发公司-咏熠科技 | 德州网站开发定制-小程序开发制作-APP软件开发-「两山开发」 | 浙江清风侠环保设备有限公司| 溶氧传感器-pH传感器|哈美顿(hamilton) | 无线遥控更衣吊篮_IC卡更衣吊篮_电动更衣吊篮配件_煤矿更衣吊篮-力得电子 | 液压油缸-液压站生产厂家-洛阳泰诺液压科技有限公司 | 隔离变压器-伺服变压器--输入输出电抗器-深圳市德而沃电气有限公司 | 蓄电池回收,ups电池后备电源回收,铅酸蓄电池回收,机房电源回收-广州益夫铅酸电池回收公司 | 高温链条油|高温润滑脂|轴承润滑脂|机器人保养用油|干膜润滑剂-东莞卓越化学 | 北京律师事务所_房屋拆迁律师_24小时免费法律咨询_云合专业律师网 | 搅拌磨|搅拌球磨机|循环磨|循环球磨机-无锡市少宏粉体科技有限公司 | 附着力促进剂-尼龙处理剂-PP处理剂-金属附着力处理剂-东莞市炅盛塑胶科技有限公司 | 蜘蛛车-高空作业平台-升降机-高空作业车租赁-臂式伸缩臂叉装车-登高车出租厂家 - 普雷斯特机械设备(北京)有限公司 | 合肥宠物店装修_合肥宠物美容院装修_合肥宠物医院设计装修公司-安徽盛世和居装饰 | 陕西华春网络科技股份有限公司| 渗透仪-直剪仪-三轴仪|苏州昱创百科 | 中山市派格家具有限公司【官网】| 超声波气象站_防爆气象站_空气质量监测站_负氧离子检测仪-风途物联网 | 警用|治安|保安|不锈钢岗亭-售货亭价格-垃圾分类亭-移动厕所厂家-苏州灿宇建材 | 电脑知识|软件|系统|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网 | 运动木地板厂家,篮球场木地板品牌,体育场馆木地板安装 - 欧氏运动地板 | 无缝钢管-聊城无缝钢管-小口径无缝钢管-大口径无缝钢管 - 聊城宽达钢管有限公司 | 苏州工作服定做-工作服定制-工作服厂家网站-尺品服饰科技(苏州)有限公司 | wika威卡压力表-wika压力变送器-德国wika代理-威卡总代-北京博朗宁科技 | 剪刃_纵剪机刀片_分条机刀片-南京雷德机械有限公司 | 英思科GTD-3000EX(美国英思科气体检测仪MX4MX6)百科-北京嘉华众信科技有限公司 | 散热器厂家_暖气片_米德尔顿散热器| IWIS链条代理-ALPS耦合透镜-硅烷预处理剂-上海顶楚电子有限公司 lcd条形屏-液晶长条屏-户外广告屏-条形智能显示屏-深圳市条形智能电子有限公司 | 高速龙门架厂家_监控杆_多功能灯杆_信号灯杆_锂电池太阳能路灯-鑫世源照明 | 全钢实验台,实验室工作台厂家-无锡市辰之航装饰材料有限公司 | 舞台木地板厂家_体育运动木地板_室内篮球馆木地板_实木运动地板厂家_欧氏篮球地板推荐 | 农业仪器网 - 中国自动化农业仪器信息交流平台 | 云阳人才网_云阳招聘网_云阳人才市场_云阳人事人才网_云阳人家招聘网_云阳最新招聘信息 |