vue如何通過image-conversion實(shí)現(xiàn)圖片壓縮詳解
簡介
vue項(xiàng)目中,上傳圖片時(shí)如果圖片很大,通過 image-conversion 壓縮到指定大小
1. 安裝依賴
npm i image-conversion --save
2. 引用
import * as imageConversion from 'image-conversion'
3. 使用
const newFile = new Promise((resolve) => {
// 壓縮到500KB,這里的500就是要壓縮的大小,可自定義
imageConversion.compressAccurately(file, 500).then(res => {
resolve(res)
}).finally(() => {
console.log('將圖片文件壓縮到了500kb')
})
})
4. 實(shí)際場景應(yīng)用
<!-- 上傳按鈕 --> <el-upload action="" class="upload" multiple accept=".png, .jpg, .jpeg" :before-upload="beforeDocumentUpload" :http-request="beforeAvatarUpload" :on-preview="handlePictureCardPreview" :before-remove="handlerBeforeRemove" :file-list="pictureList" :limit="10" :on-exceed="handleExceed" list-type="picture-card" > <i class="el-icon-plus" /> </el-upload> <!-- 預(yù)覽大圖 --> <el-dialog :visible.sync="imgVisible" :append-to-body="true"> <img width="100%" :src="dialogImageUrl" alt=""> </el-dialog>
methods:
methods: {
// 上傳前
beforeDocumentUpload(file) {
const size = file.size / 1024 / 1024
// 上傳的圖片大小不能超過10M
if (size > 10) {
this.$message.warning('文件大小不能超過10M!')
return false
}
const extension = this.getFileType(file)
// 只支持 png, jpg, jpeg 格式
if (!['png', 'jpg', 'jpeg'].includes(extension)) {
this.$message.warning('只能上傳png、jpg、jpeg格式文件!')
return false
}
// 大于0.5M壓縮成0.5M
if (size > 0.5) {
const loading = this.$loading({
lock: true,
text: '加載中'
})
// 壓縮
const newFile = new Promise((resolve) => {
// 壓縮到500KB,這里的500就是要壓縮的大小,可自定義
imageConversion.compressAccurately(file, 500).then(res => {
resolve(res)
}).finally(() => {
loading.close()
})
})
console.log('newFIle', newFile)
return newFile
}
return true
},
// 上傳
beforeAvatarUpload(file) {
const self = this
const reader = new FileReader()
reader.readAsDataURL(file.file)
reader.onload = function(e) {
// const img_base64 = e.target.result
// 自定義數(shù)組對象,傳給后臺的數(shù)據(jù)
self.imgBase64Array.push({
uid: file.file.uid,
base64Str: file
// base64Str: img_base64
})
}
},
// 預(yù)覽大圖
handlePictureCardPreview(file) {
this.dialogImageUrl = file.url
this.imgVisible = true
},
// 刪除圖片
handlerBeforeRemove(file, fileList) {
this.imgBase64Array = this.imgBase64Array.filter((p) => p.uid !== file.uid)
},
handleExceed() {
this.$message.warning('圖片數(shù)量最多為10張')
},
},總結(jié)
到此這篇關(guān)于vue如何通過image-conversion實(shí)現(xiàn)圖片壓縮的文章就介紹到這了,更多相關(guān)vue image-conversion實(shí)現(xiàn)圖片壓縮內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue ECharts直角坐標(biāo)系配置詳細(xì)講解
數(shù)據(jù)的重要性我們大家都知道,就算再小的項(xiàng)目中都可能使用幾個(gè)圖表展示,我最近在做項(xiàng)目的過程中也是需要用到圖表,最后選擇了echarts圖表庫2022-12-12
KKFileView結(jié)合vue多格式文件在線預(yù)覽功能實(shí)現(xiàn)
kkFileView是git的開源在線文件預(yù)覽項(xiàng)目,這篇文章主要介紹了KKFileView結(jié)合vue多格式文件在線預(yù)覽功能,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02
vue中{{}},v-text和v-html區(qū)別與應(yīng)用詳解
這篇文章主要介紹了vue中{{}},v-text和v-html區(qū)別與應(yīng)用詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
Vue實(shí)現(xiàn)計(jì)數(shù)器案例
這篇文章主要為大家詳細(xì)介紹了Vue計(jì)數(shù)器案例的實(shí)現(xiàn)方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06
vue3使用vuedraggable和grid實(shí)現(xiàn)自定義拖拽布局方式
這篇文章主要介紹了vue3使用vuedraggable和grid實(shí)現(xiàn)自定義拖拽布局方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
vue2.0 element-ui中el-select選擇器無法顯示選中的內(nèi)容(解決方法)
這篇文章主要介紹了vue2.0 element-ui中的el-select選擇器無法顯示選中的內(nèi)容,在文中小編使用的是element-ui V2.2.3。具體解決方法及示例代碼大家參考下本文2018-08-08
Vue?echarts實(shí)例項(xiàng)目商家銷量統(tǒng)計(jì)圖實(shí)現(xiàn)詳解
Echarts,它是一個(gè)與框架無關(guān)的?JS?圖表庫,但是它基于Js,這樣很多框架都能使用它,例如Vue,估計(jì)IONIC也能用,因?yàn)槲业牧?xí)慣,每次新嘗試做一個(gè)功能的時(shí)候,總要新創(chuàng)建個(gè)小項(xiàng)目,做做Demo2022-09-09
Vue中通過vue-router實(shí)現(xiàn)命名視圖的問題
這篇文章主要介紹了在Vue中通過vue-router實(shí)現(xiàn)命名視圖,本文給大家提到了vue-router的原理解析,給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04
Vue中使用crypto-js AES對稱加密算法實(shí)現(xiàn)加密解密
?在數(shù)字加密算法中,通過可劃分為對稱加密和非對稱加密,本文主要介紹了Vue中使用crypto-js AES對稱加密算法實(shí)現(xiàn)加密解密,文中根據(jù)實(shí)例編碼詳細(xì)介紹的十分詳盡,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03

