uniapp-图片压缩(适配H5,APP)

uniapp本身是自带压缩图片的方式的,但是他只适用于APP,做不到多端的适配,如果只考虑app,就非常容易实现了。

使用uni.compressImage()这个API即可

javascript 复制代码
compressImage(url) {
	return new Promise((reslove, reject) => {
		   const tempFilePath = url //url是选中图片的路径
		   uni.compressImage({ 
		       src: tempFilePath,
		       quality: 50, //压缩的程度
		       success: (res) => {
					reslove(res.tempFilePath) //压缩成功返回的路径
		       },
		       fail: (error) => {
		            console.log('压缩失败', error)
		       }
		   })	
		})
	},

要适配H5和APP可以使用canvas的方式进行压缩

原理:按照需求等比例创建空白画布,将图片粘到画布上,最后保存画布的base64流

javascript 复制代码
translate(imgSrc, scale) {
	//imgSrc:图片的路径
	//scale:缩放比例 0-1之间
	return new Promise((reslove, reject) => {
		var img = new Image(); //创建Image对象生成一个<img>标签
		img.src = imgSrc; //将图片路径赋给<img>标签的src
		img.onload = () => {//onload在图片加载成功后触发,在onload中完成压缩功能
			var h = img.height/2; // 获取原本图片的宽高
			var w = img.width/2;  //默认按比例压缩,根据需求修改
			var canvas = document.createElement('canvas');//创建画布
			var ctx = canvas.getContext('2d');  //设置为2d效果
			var width = document.createAttribute("width"); //创建属性节点
			width.nodeValue = w; //设置属性值
			var height = document.createAttribute("height");
			height.nodeValue = h;
			canvas.setAttributeNode(width); //设置画布宽高
			canvas.setAttributeNode(height);
			ctx.drawImage(img, 0, 0, w,h);//将图片贴到画布上
			//img:图片 0,0:粘贴的位置 w,h:粘贴图片的大小
			var base64 = canvas.toDataURL('image/png', scale);
			//'image/png':压缩返回图片的类型 scale:图片质量
			//如果要base64的流,可以直接将结果返回了
			canvas = null; //清除画布
			var blob = this.base64ToBlob(base64); //需要二进制流调用该方法拿到
			let blobUrl = window.URL.createObjectURL(blob);//blob地址
			reslove(blobUrl)
		}
	})
 },
// base64转Blob
base64ToBlob(base64) { 
	var arr = base64.split(','),
	mime = arr[0].match(/:(.*?);/)[1],
	bstr = atob(arr[1]),
	n = bstr.length,
	u8arr = new Uint8Array(n);
	while (n--) {
		u8arr[n] = bstr.charCodeAt(n);
	}
	return new Blob([u8arr],  {
		type: mime,
	});
},
相关推荐
Blurpath住宅代理6 分钟前
网页抓取(Web Scraping)完整技术指南:从原理到实战
前端
钰fly10 分钟前
Halcon联合编程适应图像的方法(picture)
开发语言·前端·javascript
束尘12 分钟前
Vue3一键复制图片到剪贴板
开发语言·javascript·vue.js
木斯佳19 分钟前
前端八股文面经大全:字节跳动前端一面·深度解析(Plus Ultra版)(2026-03-30)·面经深度解析
前端·设计模式·八股·光栅化
酉鬼女又兒21 分钟前
零基础快速入门前端DOM 节点操作核心知识点及蓝桥杯 Web 应用开发考点解析(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯
LXXgalaxy23 分钟前
Vue3 + TypeScript 组件开发速查表新手速成手册
前端·javascript·typescript
AnalogElectronic39 分钟前
uniapp学习6,滚动字幕播报
javascript·学习·uni-app
全马必破三1 小时前
Vue3+Node.js 实现AI流式输出全解析
前端·javascript·node.js
belldeep1 小时前
前端:TypeScript 版本 2 , 3 , 4 , 5 , 6 有什么差别?
前端·javascript·typescript
狗都不学爬虫_1 小时前
JS逆向 - Akamai阿迪达斯(三次) 补环境、纯算
javascript·爬虫·python·网络爬虫·wasm