JavaScript基本数据类型之Number,我的阿里春招之路分享

number

number

再次补充:在 JS 中,只要是数,就是 Number 数值型的。无论整浮、浮点数(即小数)、无论大小、无论正负,都是 Number 类型的。

✨数值范围

由于内存的限制,ECMAScript 并不能保存世界上所有的数值。

  • 最大值:Number.MAX_VALUE,这个值为: 1.7976931348623157e+308

  • 最小值:Number.MIN_VALUE,这个值为: 5e-324

如果使用 Number 表示的变量超过了最大值,则会返回Infinity。

  • 无穷大(正无穷):Infinity

  • 无穷小(负无穷):-Infinity

注意:typeof Infinity的返回结果是number。

🎉提示

整数精度:-253~253,超过这个范围,整数将会失去尾部的精确度。(这个问题 便利蜂 面过我)

✨进制转换

在JavaScript中,可以将用Number的toString(x)方法把十进制数转为其他进制。

var n = 32;

console.log(n.toString(2)); //返回字符串10000

console.log(n.toString(4)); //返回字符串200

console.log(n.toString(16)); //返回字符串20

console.log(n.toString(30)); //返回字符串12

console.log(n.toString(32)); //返回字符串10

🎉提示

对于数值直接量,不能直接调用toString(),必须用小括号强制运算数值直接量后,才可以调用该方法

console.log(32.toString(2)) //错误

console.log((32).toString(2)) //返回字符串10000

✨NaN

NaN:是一个特殊的数字,表示Not a Number,非数值。比如:

  • ‘0’ //0

  • ‘abc’ //NaN

//单独一个+跟上一个字符串,默认会首选转为number。

console.log(“abc” / 18); //结果是NaN

console.log(“abc” * “abcd”); //按理说,字符串相乘是没有结果的,但如果你非要让JS去算,它就一定会给你一个结果。结果是NaN

注意:typeof NaN的返回结果是 number。

Undefined和任何数值计算的结果为 NaNNaN 与任何值都不相等,包括 NaN 本身。即NaN===NaN:false

🎉为了方便检验NaN值,JavaScript提供了 isNaN() 函数

isNaN(NaN) //true

isNaN(0) //false

isNaN(‘asdf’) //true

isNaN(‘1’) //false

//对字符串量,isNaN会尽可能将其转为number。即先想办法转换,然后在判断。

✨连字符和加号的区别

键盘上的+可能是连字符,也可能是数字的加号。如下:

console.log(“我” + “爱” + “你”); //连字符,把三个独立的汉字,连接在一起了

console.log(“我+爱+你”); //原样输出

console.log(1+2+3); //输出6

输出:

小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:前端)
img

总结:

  • 函数式编程其实是一种编程思想,它追求更细的粒度,将应用拆分成一组组极小的单元函数,组合调用操作数据流;

  • 它提倡着 纯函数 / 函数复合 / 数据不可变, 谨慎对待函数内的 状态共享 / 依赖外部 / 副作用;

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

Tips:

其实我们很难也不需要在面试过程中去完美地阐述出整套思想,这里也只是浅尝辄止,一些个人理解而已。博主也是初级小菜鸟,停留在表面而已,只求对大家能有所帮助,轻喷🤣;

我个人觉得: 这些编程范式之间,其实并不矛盾,各有各的 优劣势

理解和学习它们的理念与优势,合理地 设计融合,将优秀的软件编程思想用于提升我们应用;

所有设计思想,最终的目标一定是使我们的应用更加 解耦颗粒化、易拓展、易测试、高复用,开发更为高效和安全

美地阐述出整套思想,这里也只是浅尝辄止,一些个人理解而已。博主也是初级小菜鸟,停留在表面而已,只求对大家能有所帮助,轻喷🤣;

我个人觉得: 这些编程范式之间,其实并不矛盾,各有各的 优劣势

理解和学习它们的理念与优势,合理地 设计融合,将优秀的软件编程思想用于提升我们应用;

所有设计思想,最终的目标一定是使我们的应用更加 解耦颗粒化、易拓展、易测试、高复用,开发更为高效和安全

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值