本文介绍了Vue使用mixins实现压缩图片代码,分享给大家,具体如下:
图片压缩
创建mixins image-compress.js
export default { methods: { /** * 检查并压缩图片大小 */ checkAndHandleCompression(file) { return new Promise((resolve, reject) => { this.imgBase64(file, (image, canvas) => { let maxSize = 2 * 1024; // 2M (单位KB) let fileSize = file.size / 1024; // 图片大小 (单位KB) let uploadSrc, uploadFile; if (fileSize > maxSize) { // 如果图片大小大于maxSize,进行压缩 uploadSrc = canvas.toDataURL(file.type, maxSize / fileSize); uploadFile = this.convertBase64UrlToFile(uploadSrc, file.name); // 转成file文件 } else { uploadSrc = image.src; uploadFile = file; } let compressedSize = uploadFile.size / 1024;// 压缩后图片大小 (单位KB) // 判断图片大小是否小于maxSize,如果大于则继续压缩至小于为止 if (compressedSize.toFixed(2) > maxSize) { this.checkAndHandleUpload(uploadFile); } else { let fileOptions = {uploadSrc, uploadFile}; resolve(fileOptions); } }); }); }, /** * 将图片转化为base64 */ imgBase64(file, callback) { // 看支持不支持FileReader if (!file || !window.FileReader) return; // 创建一个 Image 对象 let image = new Image(); // 绑定 load 事件处理器,加载完成后执行 image.onload = function () { // 创建 canvas DOM 对象 let canvas = document.createElement('canvas'); // 返回一个用于在画布上绘图的环境, '2d' 指定了您想要在画布上绘制的类型 let ctx = canvas.getContext('2d'); // 如果高度超标 // 参数,最大高度 let MAX_HEIGHT = 3000; if (image.height > MAX_HEIGHT) { // 宽度等比例缩放 *= image.width *= MAX_HEIGHT / image.height; image.height = MAX_HEIGHT; } // 获取 canvas的 2d 环境对象, // 可以理解Context是管理员,canvas是房子 ctx.clearRect(0, 0, canvas.width, canvas.height); // 重置canvas宽高 canvas.width = image.width; canvas.height = image.height; // 将图像绘制到canvas上 ctx.drawImage(image, 0, 0, image.width, image.height); callback(image, canvas); }; if (/^image/.test(file.type)) { // 创建一个reader let reader = new FileReader(); // 将图片将转成 base64 格式 reader.readAsDataURL(file); // 读取成功后的回调 reader.onload = function () { // 设置src属性,浏览器会自动加载。 // 记住必须先绑定事件,才能设置src属性,否则会出同步问题。 image.src = this.result; }; } }, /** * 把Base64转换成file文件 */ convertBase64UrlToFile(dataurl, filename) { let arr = dataurl.split(','), mime = arr[0].match(/:(.*"htmlcode"><template> ... </template> <script> import imageUploadMixins from '@/mixins/image-compress'; export default { mixins: [imageUploadMixins], ... methods:{ handleUploadImage(e){ let file = e.target.files[0]; this.checkAndHandleCompression(file).then( fileOptions => { // let {uploadSrc, uploadFile} = fileOptions; // 压缩完成使用 uploadSrc, uploadFile ... }); } } ... } </script> <style> ... </style>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“Vue使用mixins实现压缩图片代码”评论...
更新动态
2024年11月13日
2024年11月13日
- 群星.1996-风月电影原声带【滚石】【WAV+CUE】
- Blast Slam S1参赛名单出炉:XG被直邀
- 《英雄联盟》Doinb想让Tian当教练:世纪大和解?
- 《忆蚀》Subliminal:揭秘后室之谜,路知行献声Weplay文化展
- 那英《征服NEWXRCD台湾版》日本压制[WAV+CUE]
- 群星《金曲百分百上》3CD(香港版)[WAV+CUE]
- 刘欢《雨中的树(新歌加精选)2CD》德国HD24K金碟[WAV+CUE]
- 郑源 《世间情歌》6N纯银SQCD[WAV+CUE][1G]
- 群星《粤潮2HQII》头版限量编号[低速原抓WAV+CUE][991M]
- 群星《2023好听新歌21》十倍音质 U盘音乐[WAV分轨][1G]
- 《热血传奇》双11感恩回馈 超值狂欢30天
- 原神5.2版本活动汇总 5.2版本活动有哪些
- 张敬轩.2010-NO.ELEVEN【环球】【WAV+CUE】
- 黄丽玲.2006-失恋无罪【艾回】【WAV+CUE】
- 阿达娃.2024-Laluna【W8VES】【FLAC分轨】