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

},

相关推荐
ᥬ 小月亮36 分钟前
Uniapp编写微信小程序,使用canvas进行绘图
微信小程序·uni-app·c#
向明天乄1 小时前
uni-app,小程序自定义导航栏实现与最佳实践
小程序·uni-app
BXCQ_xuan3 小时前
uniapp小程序轮播图高度自适应优化详解
微信小程序·小程序·uni-app
艾路菲尔6 小时前
微信小程序地图缩放scale隐性bug
微信小程序
前端开发小吴10 小时前
微信小程序预览文件 兼容性苹果
微信小程序·小程序
Good Lucky10 小时前
setData执行后操作方法-微信小程序
微信小程序·小程序·setdata
爱分享的程序员14 小时前
微信小程序执行C语言库的详细方案
c语言·微信小程序·小程序
Mark.102414 小时前
uniapp项目打包的微信小程序,设置uni-popup type=“bottom“时,底部有空隙
微信小程序·uni-app·notepad++
发呆小天才yy19 小时前
uniapp 微信小程序使用图表
前端·微信小程序·uni-app·echarts
Muxiyale1 天前
微信小程序备案的一些记录
微信小程序·小程序