<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
// 引入imgUpload方法 import * as imgUpload from "./utils/imgUpload" //外部使用 Vue.prototype.$imgUpload = imgUpload
const dataURLtoFile = (dataurl, filename) => { // 將base64轉換為file檔案 let arr = dataurl.split(',') let mime = arr[0].match(/:(.*?);/)[1] let bstr = atob(arr[1]) let n = bstr.length let u8arr = new Uint8Array(n) while (n--) { u8arr[n] = bstr.charCodeAt(n) } return new File([u8arr], filename, { type: mime }) }; const imgZip = (file) => { var _this = this; let imgZipStatus = new Promise((resolve, reject) => { let canvas = document.createElement("canvas"); // 建立Canvas物件(畫布) let context = canvas.getContext("2d"); let img = new Image(); img.src = file.content; // 指定圖片的DataURL(圖片的base64編碼資料) var Orientation = ''; img.onload = () => { //根據情況定義 // canvas.width = 400; // canvas.height = 300; canvas.width = img.width; canvas.height = img.height; context.drawImage(img, 0, 0, canvas.width, canvas.height); file.content = canvas.toDataURL(file.file.type, 0.5); // 0.92為預設壓縮質量 let files = dataURLtoFile(file.content, file.file.name); resolve(files) } }) return imgZipStatus; }; export { imgZip, }
頁面中使用:
//上傳方法 afterCard(file) { this.$imgUpload.imgZip(file).then(resData => { const formData = new FormData(); formData.append("file", resData); // 請求介面上傳圖片到伺服器 uploadImg(formData).then(res => { }) }) }
備註:
HTMLCanvasElement.getContext()
方法返回canvas的上下文,如果上下文沒有定義則返回null.
在同一個canvas上以相同的contextType
多次呼叫此方法只會返回同一個上下文。
var ctx = canvas.getContext(contextType);var ctx = canvas.getContext(contextType, contextAttributes);
是一個指示使用何種上下文,可能的值是:
"2d"
"webgl"
"webgl2"
"bitmaprenderer"
你可以在建立渲染上下文的時候設定多個屬性,例如:
canvas.getContext("webgl", { antialias: false, depth: false });
Canvas 2D API 中的CanvasRenderingContext2D.drawImage()
方法提供了多種方式在Canvas上繪製影象。
ctx.drawImage(image, dx, dy); ctx.drawImage(image, dx, dy, dWidth, dHeight); ctx.drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight);
引數:
image
繪製到上下文的元素。允許任何的 canvas 影象源
sx
可選
需要繪製到目標上下文中的,image
的矩形(裁剪)選擇框的左上角 X 軸座標。
sy
可選
需要繪製到目標上下文中的,image
的矩形(裁剪)選擇框的左上角 Y 軸座標。
sWidth
可選
需要繪製到目標上下文中的,image
的矩形(裁剪)選擇框的寬度。如果不說明,整個矩形(裁剪)從座標的sx
和sy
開始,到image
的右下角結束。
sHeight
可選
需要繪製到目標上下文中的,image
的矩形(裁剪)選擇框的高度。
dx
image
的左上角在目標canvas上X 軸座標。
dy
image
的左上角在目標canvas上Y 軸座標。
dWidth
可選
image
在目標canvas上繪製的寬度。 允許對繪製的image
進行縮放。 如果不說明, 在繪製時image
寬度不會縮放。
dHeight
可選
image
在目標canvas上繪製的高度。允許對繪製的image
進行縮放。 如果不說明, 在繪製時image
高度不會縮放。
範例:
var canvas = document.getElementById("canvas"); var ctx = canvas.getContext("2d"); var image = document.getElementById('source'); ctx.drawImage(image, 33, 71, 104, 124, 21, 20, 87, 104);
Vue vant-ui使用van-uploader實現頭像圖片上傳
https://www.jb51.net/article/248830.htm
到此這篇關於vue js實現圖片壓縮封裝方法的文章就介紹到這了,更多相關vuejs圖片壓縮內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45