這篇文章將為大家詳細(xì)講解有關(guān)如何使用canvas壓縮圖片,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

使用canvas壓縮圖片的步驟:
1、拿到圖片元素
2、繪制一個(gè)空白的canvas
3、將圖片繪制在canvas上
4、將canvas轉(zhuǎn)成base64(這里調(diào)用的方法可以實(shí)現(xiàn)壓縮,base64就可以直接放入src或者傳入后端、轉(zhuǎn)成別的格式傳輸?shù)取#?/p>
代碼實(shí)現(xiàn):
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<img src="test.png" style="width: 200px; height: 400px;" id="imgBefore">
<img src="" id="imgafter"> //待會(huì)壓縮完的圖片放入這里。
</body>
</html>
<script>
var img = document.getElementById('imgBefore') //拿到圖片元素
img.setAttribute("crossOrigin",'Anonymous') //這句話并不是必要的,如果你的圖片是一個(gè)網(wǎng)絡(luò)鏈接,
//那么canvas繪制時(shí)可能會(huì)報(bào)錯(cuò),是因?yàn)榭缬虻陌踩詥栴}。報(bào)錯(cuò)時(shí)加上就對(duì)了。
img.onload = ()=>{ //要確保圖片已經(jīng)加載完才進(jìn)行繪制,不然拿不到圖片元素會(huì)繪制出全黑的區(qū)域,就是失敗。
var width = img.width
var height = img.height
var canvas = document.createElement('canvas');
var ctx = canvas.getContext('2d');
canvas.width = width;
canvas.height = height; //以上幾步都在繪制一個(gè)canvas
ctx.drawImage(img,0,0,width,height);//將圖片繪制進(jìn)去,這里第一個(gè)參數(shù)可以接受很多格式,
//以元素為例子,詳情https://developer.mozilla.org/zh-CN/docs/Web/API/CanvasRenderingContext2D/drawImage
var base64 = canvas.toDataURL('image/jpeg',0.2); //第二個(gè)參數(shù)為壓縮的比例,越小越模糊。0-1
document.getElementById('imgafter').src = base64
}
</script>效果對(duì)比:
壓縮前

壓縮后:

關(guān)于如何使用canvas壓縮圖片就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
網(wǎng)站欄目:如何使用canvas壓縮圖片-創(chuàng)新互聯(lián)
文章來源:http://www.chinadenli.net/article8/dpoeip.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)、域名注冊(cè)、外貿(mào)網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化、服務(wù)器托管、動(dòng)態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容
網(wǎng)頁(yè)設(shè)計(jì)公司知識(shí)