查看Nubmer.prototype实例新增的方法

Posted 陌上柳絮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了查看Nubmer.prototype实例新增的方法相关的知识,希望对你有一定的参考价值。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>查看一下Nubmer.prototype实例,我们会发现多了几个全局方法add++sun+mul+div</title>
</head>

<body>
    <script type="text/javascript">
        // 加法函数
        function accAdd(arg1, arg2) {
            var r1, r2, m;
            try {
                r1 = arg1.toString().split(".")[1].length
                console.log(arg1.toString().split(".")[0]);
                console.log(arg1.toString().split(".")[1]);
            } 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
        }
        //给Number类型增加一个add方法,调用起来更加方便。
        Number.prototype.add = function (arg) {
            return accAdd(arg, this);
        }

        console.log(accAdd(0.11, 0.2));
        console.log(0.1.add(0.2));

        // 减法函数
        function accSub(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);
        }
        Number.prototype.sub = function (arg) {
            return accSub(arg, this);
        }
        console.log(accSub(0.2, 0.1));
        console.log(0.1.sub(0.2));

        // 乘法函数
        function accMul(arg1, arg2) {
            var m = 0,
                s1 = arg1.toString(),
                s2 = arg2.toString();
            try {
                m += s1.split(".")[1].length;
            } catch (e) {}
            try {
                m += s2.split(".")[1].length;
            } catch (e) {}
            console.log(s1.replace(".", ""));
            console.log(s2.replace(".", ""));
            return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m);
        }
        Number.prototype.mul = function (arg) {
            return accMul(arg, this);
        }
        console.log(accMul(0.05, 0.05));
        console.log(0.1.mul(0.2));

        // 除法函数
        function accDiv(arg1, arg2) {
            var t1 = 0,
                t2 = 0;
            var r1, r2;
            try {
                t1 = arg1.toString().split(".")[1].length;
            } catch (e) {}
            try {
                t2 = arg2.toString().split(".")[1].length;
            } catch (e) {}
            // with 语句的原本用意是为逐级的对象访问提供命名空间式的速写方式. 也就是在指定的代码区域, 直接通过节点名称调用对象。
            // with 通常被当做重复引用同一个对象中的多个属性的快捷方式,可以不需要重复引用对象本身。
            // https://blog.csdn.net/zwkkkk1/article/details/79725934
            // with(Math){
            //     r1 = Number(arg1.toString().replace(".", ""));
            //     r2 = Number(arg2.toString().replace(".", ""));
            //     return (r1/r2)*pow(10, t2-t1);
            // }
            r1 = Number(arg1.toString().replace(".", ""));
            r2 = Number(arg2.toString().replace(".", ""));
            return (r1 / r2) * Math.pow(10, t2 - t1);
        }
        Number.prototype.div = function (arg) {
            return accDiv(arg, this);
        }
        console.log(accDiv(0.05, 0.05));
        console.log(0.1.div(0.2));
    </script>
</body>

</html>

 

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>查看一下Nubmer.prototype实例,我们会发现多了几个全局方法add++sun+mul+div</title>
</head>

<body>
    <script type="text/javascript">
        // 加法函数
        function accAdd(arg1arg2) {
            var r1r2m;
            try {
                r1 = arg1.toString().split(".")[1].length
                console.log(arg1.toString().split(".")[0]);
                console.log(arg1.toString().split(".")[1]);
            } catch (e) {
                r1 = 0
            }
            try {
                r2 = arg2.toString().split(".")[1].length
            } catch (e) {
                r2 = 0
            }
            m = Math.pow(10Math.max(r1r2))
            return (arg1 * m + arg2 * m) / m
        }
        //给Number类型增加一个add方法,调用起来更加方便。
        Number.prototype.add = function (arg) {
            return accAdd(argthis);
        }

        console.log(accAdd(0.110.2));
        console.log(0.1.add(0.2));

        // 减法函数
        function accSub(arg1arg2) {
            var r1r2mn;
            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(10Math.max(r1r2));
            n = (r1 >= r2) ? r1 : r2;
            return ((arg1 * m - arg2 * m) / m).toFixed(n);
        }
        Number.prototype.sub = function (arg) {
            return accSub(argthis);
        }
        console.log(accSub(0.20.1));
        console.log(0.1.sub(0.2));

        // 乘法函数
        function accMul(arg1arg2) {
            var m = 0,
                s1 = arg1.toString(),
                s2 = arg2.toString();
            try {
                m += s1.split(".")[1].length;
            } catch (e) {}
            try {
                m += s2.split(".")[1].length;
            } catch (e) {}
            console.log(s1.replace("."""));
            console.log(s2.replace("."""));
            return Number(s1.replace(".""")) * Number(s2.replace(".""")) / Math.pow(10m);
        }
        Number.prototype.mul = function (arg) {
            return accMul(argthis);
        }
        console.log(accMul(0.050.05));
        console.log(0.1.mul(0.2));

        // 除法函数
        function accDiv(arg1arg2) {
            var t1 = 0,
                t2 = 0;
            var r1r2;
            try {
                t1 = arg1.toString().split(".")[1].length;
            } catch (e) {}
            try {
                t2 = arg2.toString().split(".")[1].length;
            } catch (e) {}
            // with 语句的原本用意是为逐级的对象访问提供命名空间式的速写方式. 也就是在指定的代码区域, 直接通过节点名称调用对象。
            // with 通常被当做重复引用同一个对象中的多个属性的快捷方式,可以不需要重复引用对象本身。
            // https://blog.csdn.net/zwkkkk1/article/details/79725934
            // with(Math){
            //     r1 = Number(arg1.toString().replace(".", ""));
            //     r2 = Number(arg2.toString().replace(".", ""));
            //     return (r1/r2)*pow(10, t2-t1);
            // }
            r1 = Number(arg1.toString().replace("."""));
            r2 = Number(arg2.toString().replace("."""));
            return (r1 / r2) * Math.pow(10t2 - t1);
        }
        Number.prototype.div = function (arg) {
            return accDiv(argthis);
        }
        console.log(accDiv(0.050.05));
        console.log(0.1.div(0.2));
    </script>
</body>

</html>

以上是关于查看Nubmer.prototype实例新增的方法的主要内容,如果未能解决你的问题,请参考以下文章

ES6学习—字符串的新增方法

PHP7新增功能详解(实例)

ES6字符串对象的新增11种实例方法必知

MyBatis-plus 新增实例,主键ID从很大的数字开始

ES 新增字符串方法

ES6新增语法(四)——面向对象