uniapp 之 Base64图片的显示问题以及保存到相册

一、base64 图片显示问题

  uniapp 官网明文指出 image 标签的 src 支持base64 码:
在这里插入图片描述
  但是实际操作还需要注意一个点,base64码可能过长,过长的情况就可能存在换行符\r \n,所以我们就需要把换行符给处理掉:

let base64 = 'data:image/jpeg;base64,/9h/5SAESkZJTgA......'
this.imageSrc = base64.replace(/[\r\n]/g, "")

  之后,就可以正常显示图片了,亲测有效

  
  

二、base64 图片保存到相册

话不多说,直接上代码:

// 将base64 图片保存到本地系统相册
saveBaseImgFile(base64) {
	const bitmap = new plus.nativeObj.Bitmap('base64')
	bitmap.loadBase64Data(base64, () => {
			const url = '_doc/' + new Date().getTime() + '.png'
			bitmap.save(
				url,
				{
					overwrite: true // 是否覆盖
					// quality: 'quality'  // 图片清晰度
				},
				(i) => {
					uni.saveImageToPhotosAlbum({
						filePath: url,
						success: () => {
							toast('图片保存成功')
							bitmap.clear()
						}
					})
				},
				(e) => {
					toast('图片保存失败')
					bitmap.clear()
				}
			)
		},
		(e) => {
			toast('图片保存失败')
			bitmap.clear()
		}
	)
}

如有不足,望大家多多指点! 谢谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhuangv

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值