微信小程序跳2

// 图片压缩

compressImage (image = {}, options = {}) {

return new Promise((resolve, reject) => {

const { width = 0 } = image

const { compressAfterSizeFlag = false, scaleFlag = false, scaleTargetWidth = 768 } = options

// 超过100k压缩

const maxFileSizeLimit = 100 * 1024

if (image.size > maxFileSizeLimit) {

const fileSize = image.size / 1024

// 初始压缩率80

let quality = 80

if (fileSize > 200 && fileSize <= 500) {

// 200 以上,500k以内的图片,压缩70

quality = 60

} else if (fileSize > 500 && fileSize <= 1024) {

// 500 以上,1M以内的图片,压缩50

quality = 40

} else if (fileSize > 1024 && fileSize <= 2048) {

// 1M 以上,2M以内的图片,压缩30

quality = 30

} else if (fileSize > 2048 && fileSize <= 5012) {

// 2M 以上,5M以内的图片,压缩20

quality = 20

} else if (fileSize > 5012) {

// 5M以上的图片,压缩10

quality = 10

}

// 开始压缩

const option = {

src: image.filePath,

quality: quality,

success: res => {

image.compressPath = res.tempFilePath

if (compressAfterSizeFlag) {

// 获取压缩后的大小

uni.getFileSystemManager().readFile({

filePath: res.tempFilePath,

success: ({ data }) => {

image.compressSize = data.byteLength

resolve(image)

},

fail: _ => resolve(image)

})

} else {

resolve(image)

}

},

fail: _ => {

resolve(image)

}

}

// 缩放图片

if (scaleFlag && width > scaleTargetWidth) {

option.compressedWidth = scaleTargetWidth

}

uni.compressImage(option)

} else {

resolve(image)

}

})

},

// 四舍五入

toFixed (value = 0, decimal = 2) {

if (!value || isNaN(Number(value))) {

return value

}

let valueStr = String(value)

if (valueStr.length < 2 || valueStr.lastIndexOf('.') < 0) {

return value

}

const multiplier = Math.pow(10, decimal + 1)

const valueMultiplier = Math.trunc(value * multiplier)

const valueMultiplierStr = String(valueMultiplier)

return (Number(valueMultiplierStr.substring(0, valueMultiplierStr.length - 1))

  • (Number(valueMultiplierStr.substring(valueMultiplierStr.length - 1)) >= 5 ? 1 : 0)) / Math.pow(10, decimal)

},

相关推荐
小咕聊编程8 分钟前
【含文档+PPT+源码】基于微信小程序的点餐系统的设计与实现
微信小程序·小程序
2501_9159184116 小时前
如何在iPad上找到并打开文件夹的完整指南
android·ios·小程序·uni-app·iphone·webview·ipad
shejizuopin17 小时前
基于Spring Boot+小程序的非遗科普平台设计与实现(毕业论文)
spring boot·后端·小程序·毕业设计·论文·毕业论文·非遗科普平台设计与实现
StarChainTech20 小时前
一站式租车平台革新:从信用免押到全流程可视化管理的技术实践
大数据·人工智能·微信小程序·小程序·软件需求
CHU7290351 天前
一番赏盲盒抽卡机小程序:探索惊喜与互动的多元功能体验
小程序
换日线°1 天前
微信小程序对接位置服务(腾讯、高德)完成路径规划
前端·微信小程序·vue
2501_915918411 天前
Wireshark、Fiddler、Charles抓包工具详细使用指南
android·ios·小程序·https·uni-app·iphone·webview
晨港飞燕1 天前
Notepad++使用技巧
notepad++
苏苏哇哈哈1 天前
微信小程序实现仿腾讯视频小程序首页圆角扩散轮播组件
微信小程序·小程序·轮播图
code袁1 天前
基于微信小程序的宿舍维修小程序的设计与实现
微信小程序·小程序·毕业设计·springboot·notepad++·宿舍维修小程序