Number.prototype.add = function (arg) {
var r1, r2, m;
try { r1 = this.toString().split(".")[1].length } catch (e) { r1 = 0 }
try { r2 = arg.toString().split(".")[1].length } catch (e) { r2 = 0 }
m = Math.pow(10, Math.max(r1, r2))
return (this * m + arg * m) / m
}
Number.prototype.sub = function (arg) {
return this.add(-arg);
}
Number.prototype.mul = function (arg) {
var m = 0, s1 = this.toString(), s2 = arg.toString();
try { m += s1.split(".")[1].length } catch (e) { }
try { m += s2.split(".")[1].length } catch (e) { }
return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m)
}
Number.prototype.div = function (arg) {
var t1 = 0, t2 = 0, r1, r2;
try { t1 = this.toString().split(".")[1].length } catch (e) { }
try { t2 = arg.toString().split(".")[1].length } catch (e) { }
with (Math) {
r1 = Number(this.toString().replace(".", ""))
r2 = Number(arg.toString().replace(".", ""))
return (r1 / r2) * pow(10, t2 - t1);
}
}
var floatObj = function () {
function isInteger(obj) {
return Math.floor(obj) === obj
}
function toInteger(floatNum) {
var ret = { times: 1, num: 0 }
if (isInteger(floatNum)) {
ret.num = floatNum
return ret
}
var strfi = floatNum + ''
var dotPos = strfi.indexOf('.')
var len = strfi.substr(dotPos + 1).length
var times = Math.pow(10, len)
var intNum = parseInt(floatNum * times + 0.5, 10)
ret.times = times
ret.num = intNum
return ret
}
function operation(a, b, digits, op) {
var o1 = toInteger(a)
var o2 = toInteger(b)
var n1 = o1.num
var n2 = o2.num
var t1 = o1.times
var t2 = o2.times
var max = t1 > t2 ? t1 : t2
var result = null
switch (op) {
case 'add':
if (t1 === t2) {
result = n1 + n2
} else if (t1 > t2) {
result = n1 + n2 * (t1 / t2)
} else {
result = n1 * (t2 / t1) + n2
}
return result / max
case 'subtract':
if (t1 === t2) {
result = n1 - n2
} else if (t1 > t2) {
result = n1 - n2 * (t1 / t2)
} else {
result = n1 * (t2 / t1) - n2
}
return result / max
case 'multiply':
result = (n1 * n2) / (t1 * t2)
return result
case 'divide':
result = (n1 / n2) * (t2 / t1)
return result
}
}
function add(a, b, digits) {
return operation(a, b, digits, 'add')
}
function subtract(a, b, digits) {
return operation(a, b, digits, 'subtract')
}
function multiply(a, b, digits) {
return operation(a, b, digits, 'multiply')
}
function divide(a, b, digits) {
return operation(a, b, digits, 'divide')
}
function toFixed(num, s) {
try {
s = s || (num + '').split(".")[1].length;
} catch (e) { }
var times = Math.pow(10, s + 1)
var des = num * times + 5
des = parseInt(des / 10, 10) * 10 / times
return des + ''
}
return {
add: add,
subtract: subtract,
multiply: multiply,
divide: divide,
toFixed: toFixed
}
}();
const abc = floatObj.toFixed(2.1,2)
const accAdd = (arg1, arg2) => {
var r1, r2, m
try {
r1 = arg1.toString().split('.')[1].length
} catch (e) {
r1 = 0
}
try {
r2 = arg2.toString().split('.')[1].length
} catch (e) {
r2 = 0
}
m = Math.pow(10, Math.max(r1, r2))
return (arg1 * m + arg2 * m) / m
}
const subtr = (arg1, arg2) => {
var r1, r2, m, n
try {
r1 = arg1.toString().split('.')[1].length
} catch (e) {
r1 = 0
}
try {
r2 = arg2.toString().split('.')[1].length
} catch (e) {
r2 = 0
}
m = Math.pow(10, Math.max(r1, r2))
n = (r1 >= r2) ? r1 : r2
return ((arg1 * m - arg2 * m) / m).toFixed(n)
}
const accMul = (arg1, arg2) => {
var m = 0; var s1 = arg1.toString(); var s2 = arg2.toString()
try { m += s1.split('.')[1].length } catch (e) { console.log(e) }
try { m += s2.split('.')[1].length } catch (e) { console.log(e) }
return Number(s1.replace('.', '')) * Number(s2.replace('.', '')) / Math.pow(10, m)
}
const accDiv = (arg1, arg2) => {
var t1 = 0; var t2 = 0; var r1; var r2
try { t1 = arg1.toString().split('.')[1].length } catch (e) { console.log(e) }
try { t2 = arg2.toString().split('.')[1].length } catch (e) { console.log(e) }
r1 = Number(arg1.toString().replace('.', ''))
r2 = Number(arg2.toString().replace('.', ''))
return (r1 / r2) * Math.pow(10, t2 - t1)
}
const accRound = (value, n) => {
if (!n) n = 2
return Math.round(value * Math.pow(10, n)) / Math.pow(10, n)
}