前端无用知识

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值