为什么JS中数值类型已经可以使用Number方法,还要引入Number对象概念?

JS中数值类型已经可以使用Number方法,为什么还要引入Number对象概念呢?也就是说:
var n1 = 10;
var n2 = new Number(10)
n1 和 n2的区别在哪里呢,二者都可以:
n1.toString()
n2.toString()
结果都一样。
除了typeof不同。
另外Number.isInteger(n1) 返回true
而Number.isInteger(n2)却返回false,Number.isInteger()不是对象方法吗,怎么反而是false?
拜托高手帮忙解答,多谢了

JavaScript中,数值类型有两种表示方式:直接量和Number对象。这两种表示方式在大多数情况下是等价的,但是它们有一些重要的区别。
直接量(也称为原始值)表示一个数值常量,它直接写在代码中,例如10或者3.14。直接量是不可变的,它们是原始类型的值,不能调用方法,只能进行基本的运算。
Number对象表示一个数值,但是它是一个对象,而不是原始类型的值。Number对象可以调用方法来执行更高级的操作,比如转换为字符串、比较大小等。但是,由于Number对象是可变的,所以它的性能要比直接量差一些。
所以,通常来说,我们应该优先使用直接量来表示数值,只有在需要使用Number对象的方法时才使用Number对象。
对于上面的例子,n1和n2两者都可以调用toString()方法来将数值转换为字符串,但是n2是一个Number对象,所以它可以调用更多的方法。例如,使用Number.isInteger()方法检查一个数值是否为整数时,n1是直接量,所以它可以直接传入`Number
另外,由于Number.isInteger()方法是Number对象的一个静态方法,而不是实例方法,所以它无法直接在Number对象实例上调用。例如,在上面的例子中,Number.isInteger(n1)返回true,因为n1是一个直接量,它可以直接传入Number.isInteger()方法;而Number.isInteger(n2)返回false,因为n2是一个Number对象实例,而不是直接量,它不能直接传入Number.isInteger()方法。

总之,直接量和Number对象两者都可以表示数值,但是它们有一些重要的区别,应该根据实际情况来选择使用哪种方式。通常来说,我们应该优先使用直接量来表示数值,只有在需要使用Number对象的方法时才使用Number对象。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2022-12-08

                                        数字类型、Number和new Number的区别

        不难看出三种类型都和数字相关,但是都有各自存在的意义,而且在实际前端开发中都比较常用。例如字符串类型数字转化为Number类型,方便计算价格等等。接下来做个全面讲解,结合源码和贴近开发案例。

1、 数字类型: let num1 = 100,在js中表示声明一个数字类型变量,实质上也是把数字转化成Numer对象,所以可以调用toString()方法,可以用来参与加减乘除的数学计算,例如num1 *1=100,num1+1=101,num1-1=99,num1 /1=100;

2、Number类型:用于将后端接口返回的字符串转化成数字类型,和定义数字变量全等关系,比如价格 let num2 = '100',除了显示在页面,还可以转化成数字类型 const num3 = Number(num2 ),还能保留有效小数位,比如const num3 = Number(num2 ).toFixed(2),输出结果 100.00;

3、new Number类型:new Number(100),是把数字字符串或者数字类型转化成Number对象,因为js的new Number()后的对象用于原型链(toString)自带方法,比如toString()、valueOf()和toLocaleString()等等,详情看下图;

new Number()创建对象后的结构

比较三者:

js代码

输出结果

总结:

从实际结果不难看出,num1和num2是数字类型,num3是对象,Number 和数字类型全等,二者和new Number结果不全等。值得关注的是,一个原始类型值并没有任何可用的方法,其使用的方法是包装对象原型上的,例如:(12).toFixed(),toFixed()实际上是在Number对象原型(prototype)中声明的方法。

本回答被提问者采纳

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网