let infi = 996/0; //通过除以0得到无穷大
infi = Infinity; //直接使用Infinity关键字表示无穷大
无穷大分为正无穷和负无穷:
-1/0; //-Infinity
-Infinity;
以上代码可以直接在控制台执行。
NaN
代表计算错误,他是错误表达式的计算结果。
let nan = “str” / 2; // 字符串和数字运算
NaN
具有传递性,所有和Nan
一起计算的表达式都会返回Nan
;
NaN + 1; //NaN
NaN * 3; //NaN
NaN + Infinity; //Nan
特殊值的存在使得计算在
JavaScript
中的计算永远都是安全的。
最坏的结果就是返回一个错误值:
NaN
。
BigInt
的存在是为了弥补Number
表示的缺陷,Number
只能表示位于[ 2 5 ^5 5 3 ^3 3-1 , -(2 5 ^5 5 3 ^3 3-1) ]区间的整数。
常规情况下,使用Number
就能满足我们所有的需求,但如果是处理超高精度的计算,或者加密、时间戳等任务就需要使用BigInt
类型。
定义BigInt
类型的数据需要在整数后面添加一个字母n
,虽然看起来有点奇怪:
//尾部加n表示为BigInit类型
const bigInt = 999999999999999999999999999999999999999999999n;
由BigInt
类型使用机会较少,此处不做过多解释。
肯定就有童鞋问了,为啥只有
BigInt
,没有BigFloat
之类的类型呢?
这是因为,
BigInt
类型不限制数字的长度,也就是说不论小数点后多少位,都能够通过调整单位使小数变成整数计算
比如在计算钱的时候,通常不使用“元”为单位,记作
9.345
元,而是记作9345
厘。
只要单位足够小,总是有整数的…
字符串类型表示的是一系列字符组成的序列,必须被包含在引号里,引号有三种:
let str1 = “hello world”;
let str2 = ‘单引号字符串’;
let str3 = 反引号字符串用作特殊用途
单引号和双引号就是普通的字符串,而且二者在使用中没有区别。
反引号字符串属于特殊功能的字符串,通常用于字符串拼接:
let age = 36;
let name = “特朗普”;
let line = ${name} is ${age} years old.
alert(line);
以上功能是反引号特殊的功能,不能在单双引号中使用。
通过 ${...}
可以将外部值插入到反引号字符串中,这是非常有用的一个功能。
如果我们不使用这种方法,只能使用一种非常不优雅的方式:
let age = 36;
let name = “特朗普”;
let line = name + " is “+ age +” years old.";
alert(line);
布尔类型主要用于判断,常常结合if
语句使用,仅包含两个值:true
和false
,true
表示正确、是、存在,false
表示否、错误、不存在、未定义。
定义布尔值:
let isTrue = true;
let isOpen = false;
let notNull = true;
布尔值是比较运算符的结果:
let isBigger = 4 > 3;
alert(isBigger); // true 是的4大于3
null
表示空、不存在,是一个独立的类型,只有null
一个值。
例如,我们定义一个变量,但是并不知道给它赋一个什么值,可以赋值null
,表示空值。
let age = null;
如果我们在一个集合中查找一个值,如果没有查到就可以返回一个null
,表示没有找到。
和null
一样,undefined
同样自成一类,表示未定义。
例如,我们定义一个变量,但是不做赋值操作,那么这个变量就具有一个undefined
值:
let num ;
alert(num); // 弹出 “undefined”
object
类型表示的是对象类型,这在面向对象编程(OOP
)中非常重要。
object
类型属于复杂类型,或者说是特殊类型。
通常的Number
类型、String
类型都是单一类型,基础类型。
而object
类型则是复合类型,内部可以包含各种类型。
例如,任何一种基础类型都不能修饰“人”这个“变量”,这是因为“人”具有很多属性,例如身高、年龄、体重、姓名等。
但是这些属性都是基础类型,所以我们就可以用object
类型,将这些基础类型聚集起来,用于修饰“人”这个变量。
后面,面向对象章节会详细讲解object
知识。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
性能优化
1.webpack打包文件体积过大?(最终打包为一个js文件)
2.如何优化webpack构建的性能
3.移动端的性能优化
4.Vue的SPA 如何优化加载速度
5.移动端300ms延迟
6.页面的重构
所有的知识点都有详细的解答,我整理成了280页PDF《前端校招面试真题精编解析》。
CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!
AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算
mV0L2h1Z28yMzM=,size_16,color_FFFFFF,t_70)
一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!
AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算