微信小程序跳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)

},

相关推荐
TE-茶叶蛋19 分钟前
小程序协同编辑实战:从 Yjs 到纯 JavaScript 的重构之路
javascript·小程序·重构
前端 贾公子2 小时前
uniapp -- 暗黑模式
notepad++
前端 贾公子2 小时前
小程序 icon 解决方案 == iconify
小程序
博客zhu虎康2 小时前
音视频处理:微信小程序实现语音转文字功能
微信小程序·小程序
00后程序员张3 小时前
iOS上架工具,AppUploader(开心上架)用于证书生成、描述文件管理Xcode用于应用构建
android·macos·ios·小程序·uni-app·iphone·xcode
2501_915921433 小时前
只有 IPA 没有源码时,如何给 iOS 应用做安全处理
android·安全·ios·小程序·uni-app·iphone·webview
汤姆yu3 小时前
2026版基于微信小程序的儿童疫苗预约接种系统
微信小程序·小程序
CHU7290354 小时前
趣味抽赏,解锁惊喜——扭蛋机盲盒抽赏小程序前端功能解析
前端·小程序
毕设源码-朱学姐4 小时前
【开题答辩全过程】以 汇华商场停车位预约小程序为例,包含答辩的问题和答案
小程序
偷偷摸鱼的少年4 小时前
小程序提现功能升级改造
微信小程序