《JavaScript面试大师》系列文章的核心在于沿用应试教育的套路,采取:知识点+刷题的模式来加深巩固理解,目的在于斩获心仪offer,更高的目的在于提升对语言本身的理解,达到融会贯通。
Number类型面试题:
为什么0.1 + 0.2 = 0.30000000000000004?
给Number加一个方法newRound,可以保留小数点后n位 (1.23457.newRound(2) —> 1.23)
以下代码输出什么 Number(undefined) ,Number(null)
typeof NaN返回什么
Number()函数的转换规则
[“1”, “2”, “3”].map(parseInt) 答案是多少?
说说对parseInt(string,radix)函数的理解
说说对parseFloat(string)函数的理解
面试题1:为什么0.1 + 0.2 = 0.30000000000000004?
解答:0.1和0.2是十进制小数,对应分数是1/10和1/5,将它们用二进制表示均是循环小数,基于IEEE 754格式二进制表示循环小数实际上是截断后的近似值,相加后的值比十进制的0.3略大。可以使用toFixed()解决,或者规定允许误差
参考:
《Floating Point Math》
Is floating point math broken?
面试题2:给Number加一个方法newRound,可以保留小数点后n位 (1.23457.newRound(2) -> 1.23)
解答:运用到了原型对象,toFixed函数
Number.prototype.newRound = function(n){
return +this.toFixed(n)
}
面试题3:以下代码输出什么 Number(undefined) ,Number(null)
解答:NaN,0
面试题4:typeof NaN返回什么
解答:“number”
面试题5:Number()函数的转换规则
解答:ECMAScript®2021对于Number值转换规则定义如下:
《JavaScript高级程序设计》String转换为Number的规则如下:
字符串只包含数字(带符号),将其转换为十进制数值并忽略前导零
字符串包含有效浮点格式,将其转换为对应的浮点数值并忽略前导零
字符串包含有效的十六进制格式,将其转换为对应十进制数
字符串为空,将其转换为0
字符串包含上述格式外的字符,将其转换为NaN
ECMAScript®2021中toNumber的转换规则,实际上对首末有空格,换行的字符串做了个trim处理,如下所示:
Object转换为Number的规则如下:
调用对象的valueOf()方法,然后按上表规则转换,如果结果非NaN,返回结果;如果转换结果为NaN,执行2
调用对象的toString()方法,然后按照上表规则转换
参考:
ECMAScript®2021手册——ToNumber(arguments)
《Javascript 高级程序设计》 3.4.5 Number类型 4.数值转换
面试题6:[“1”, “2”, “3”].map(parseInt) 答案是多少?
解答:[1, NaN, NaN] ,首先需要明确arr.map(function(item, index, arr){})以及parseInt(numStr, radix),迭代数组元素的过程中,传给parseInt函数的第一个参数是item,第二个是index,因此返回结果为[parseInt(“1”, 0), parseInt(“2”, 1), parseInt(“3”, 2)],parseInt的第二个参数是进制基数,后两个元素解析错误,返回NaN
面试题7:说说对parseInt(string,radix)函数的理解
解答:函数的含义是,什么数的radix进制表示为string的有效部分。有效是ECMAScript定义的判断规则,string有效部分长度为0则该数不存在(NaN)
ECMAScript®2021对其过程定义可归纳为四步:
string转化为字符串,脱去左边的空格,换行字符;
脱去string的符号;
将基数radix转换为32Int;
从左至右,取出尽可能多的有效字符,转换后带上符号返回值
参考:ECMAScript®2021手册——parseInt(string,radix)
面试题8:说说对parseFloat(string)函数的理解
解答:parseFloat(string)解析步骤与parseInt类似,区别在于前者只解析十进制,其次是parseFloat中有效字符的判断规则应当符合StrDecimalLiteral定义
参考:ECMAScript®2021手册——parseFloat(string)