export function caculate(type, a, b) {
// 加法
function add(a, b) {
let c
let d
try {
c = a.toString().split('.')[1].length
} catch (f) {
c = 0
}
try {
d = b.toString().split('.')[1].length
} catch (f) {
d = 0
}
const e = Math.pow(10, Math.max(c, d))
return (mul(a, e) + mul(b, e)) / e
}
// 减法
function sub(a, b) {
var c, d, e
try {
c = a.toString().split('.')[1].length
} catch (f) {
c = 0
}
try {
d = b.toString().split('.')[1].length
} catch (f) {
d = 0
}
e = Math.pow(10, Math.max(c, d))
return (mul(a, e) - mul(b, e)) / e
}
// 乘法
function mul(a, b) {
let c = 0
const d = a.toString()
const e = b.toString()
try {
c += d.split('.')[1].length
} catch (f) {
// console.log('')
}
try {
c += e.split('.')[1].length
} catch (f) {
// console.log('')
}
return Number(d.replace('.', '')) * Number(e.replace('.', '')) / Math.pow(10, c)
}
// 除法
function div(a, b) {
let e = 0
let f = 0
try {
e = a.toString().split('.')[1].length
} catch (g) {
console.error(g)
}
try {
f = b.toString().split('.')[1].length
} catch (g) {
console.error(g)
}
const c = Number(a.toString().replace('.', ''))
const d = Number(b.toString().replace('.', ''))
return mul(c / d, Math.pow(10, f - e))
}
const excute = {
adds(a, b) {
return add(a, b)
},
subs(a, b) {
return sub(a, b)
},
muls(a, b) {
return mul(a, b)
},
divs(a, b) {
return div(a, b)
}
}
return excute[type](a, b)
}
解决js浮点数计算bug的自定义加减乘除函数
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
相关阅读更多精彩内容
- 福哥答案2020-08-10:浮点数=符号位+阶码+尾数,阶码加1就是浮点数的2倍值。 代码用golang编写,如...