alert( 1 / 0 ); // Infinity
isFinite() 判断Infinity
null >= 0 true
null == undefined true
两个非运算 !! 有时候用来将某个值转化为布尔类型
空值的 return 或没有 return 的函数返回值为 undefined
function doNothing() {
return;
}
alert( doNothing() === undefined ); // true
函数声明:在主代码流中声明为单独的语句的函数:
// 函数声明
function sum(a, b) {
return a + b;
}
在函数声明被定义之前,它就可以被调用。
函数表达式:在一个表达式中或另一个语法结构中创建的函数。下面这个函数是在赋值表达式 = 右侧创建的:
// 函数表达式
let sum = function(a, b) {
return a + b;
};
函数表达式是在代码执行到达时被创建,并且仅从那一刻起可用
let user = {
name, // 与 name:name 相同
age: 30
};
let obj = {
0: “test” // 等同于 “0”: “test”
};
// 都会输出相同的属性(数字 0 被转为字符串 “0”)
alert( obj[“0”] ); // test
alert( obj[0] ); // test (相同的属性)
// 旧式浏览器可能需要 polyfills.
let fruits = [“Apple”, “Orange”, “Plum”];
// 与 fruits[fruits.length-1] 相同
alert( fruits.at(-1) ); // Plum
for…in 循环适用于普通对象,并且做了对应的优化。但是不适用于数组
length 属性。准确来说,它实际上不是数组里元素的个数,而是最大的数字索引值加一
let fruits = [];
fruits[123] = “Apple”;
alert( fruits.length ); // 124
// 从 arr、[3,4]、5 和 6 创建一个新数组
alert( arr.concat([3, 4], 5, 6) ); // 1,2,3,4,5,6
const arr = [NaN];
alert( arr.indexOf(NaN) ); // -1(错,应该为 0)
alert( arr.includes(NaN) );// true(正确)
JSON 支持 object,array,string,number,boolean 和 null。
JavaScript 提供序列化(serialize)成 JSON 的方法 JSON.stringify 和解析 JSON 的方法 JSON.parse
let arr = [3, 5, 1];
alert( Math.max(…arr) ); // 5(spread 语法把数组转换为参数列表)
function f(arg1, …rest, arg2) { // arg2 在 …rest 后面?!
// error
}
若 … 出现在函数参数列表的最后,那么它就是 rest 参数,它会把参数列表中剩余的参数收集到一个数组中。
若 … 出现在函数调用或类似的表达式中,那它就是 spread 语法,它会把一个数组展开为列表。
使用场景:
Rest 参数用于创建可接受任意数量参数的函数。
Spread 语法用于将数组传递给通常需要含有许多参数的函数。
闭包 是指一个函数可以记住其外部变量并可以访问这些变量
在 JavaScript 中,所有函数都是天生闭包的(只有一个例外)
浏览器会将 setTimeout 或 setInterval 的五层或更多层嵌套调用(调用五次之后)的最小延时限制在 4ms