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

},

相关推荐
Emma歌小白7 小时前
如何首次运行小程序后端
微信小程序
赣州云智科技的技术铺子8 小时前
【一步步开发AI运动APP】十二、自定义扩展新运动项目1
微信小程序·小程序·云开发·智能小程序
2501_915918418 小时前
iOS 上架全流程指南 iOS 应用发布步骤、App Store 上架流程、uni-app 打包上传 ipa 与审核实战经验分享
android·ios·小程序·uni-app·cocoa·iphone·webview
00后程序员张10 小时前
iOS App 混淆与加固对比 源码混淆与ipa文件混淆的区别、iOS代码保护与应用安全场景最佳实践
android·安全·ios·小程序·uni-app·iphone·webview
破无差19 小时前
《赛事报名系统小程序》
小程序·html·uniapp
00后程序员张20 小时前
详细解析苹果iOS应用上架到App Store的完整步骤与指南
android·ios·小程序·https·uni-app·iphone·webview
海绵宝宝不喜欢侬1 天前
uniapp-微信小程序分享功能-onShareAppMessage
微信小程序·小程序·uni-app
2501_915106321 天前
Xcode 上传 ipa 全流程详解 App Store 上架流程、uni-app 生成 ipa 文件上传与审核指南
android·macos·ios·小程序·uni-app·iphone·xcode
亮子AI1 天前
【小程序】微信小程序隐私协议
微信小程序·小程序
weixin_177297220691 天前
短剧小程序系统开发:打造个性化娱乐新平台
小程序·娱乐·短剧