[]==![]为什么为true
为false,在两边都是相同数据类型时,==是直接比较两边数据,结果为false,因为[]属于引用类型,在两个[]分别指向不同的堆内存
节流,防抖:
防抖:
触发事件后在 n 秒内函数只能执行一次,如果在 n 秒内又触发了事件,则会重新计算函数执行时间。
节流:
连续触发事件但是在 n 秒中只执行一次函数
函数:
闭包:
闭包就是能够读取其他函数内部变量的函数。在js中,可以将闭包理解成“函数中的函数“
使用场景:节流与防抖
递归:
递归就是一个函数在它的函数体内调用它自身。执行递归函数将反复调用其自身,每调用一次就进入新的一层。递归函数必须有结束条件。
当函数在一直递推,直到遇到墙后返回,这个墙就是结束条件。
所以递归要有两个要素,结束条件与递推关系使用场景:树形菜单
回调:
回调函数就是一个被作为参数传递的函数。
JavaScript 函数是被设计为执行特定任务的代码块。
把一段需要重复使用的代码,用function语法包起来,方便重复调用,分块和简化代码。
JavaScript 函数会在某代码调用它时被执行。
函数声明方式:
- 方式一:
function 方法名(){ //要执行的代码
}
- 方式二:ES6中声明方式箭头函数,()=>{}
- 方式三:匿名函数,将函数存到变量里 var func = function(){};
函数调用:
调用方式一:名字(); 函数可以多次调用
//函数声明
function fn(){
console.log(1);
}
//函数的调用
fn();
调用方式二:在事件中调用,直接写函数名,不使用括号//函数声明
function fn(){
console.log(1);
}
//函数在事件中的调用
document.onclick = fn;
函数传参:
- 形参:形式上的参数——给函数声明一个参数;
- 实参:实际的参数——在函数调用时给形参赋的值
function func(形参1,形参2){
//函数执行代码
}
func(实参1,实参2);//调用时传参
函数返回值:
- 所有函数都会有函数返回值即函数执行后一定会返回一个结果,如果没有定义默认返回undefined;
- 在函数中,return后定义返回值;
- 在函数中,return之后的代码就不会再执行了
- return只能用于函数中,用在其他地方会报错
堆和栈区别:
1、栈由系统自动分配,而堆是人为申请开辟;
2、栈获得的空间较小,而堆获得的空间较大;
3、栈由系统自动分配,速度较快,而堆一般速度比较慢;
4、栈是连续的空间,而堆是不连续的空间。
什么是原型链:
每个对象都可以有一个原型_proto_,这个原型还可以有它自己的原型,以此类推,形成一个原型链。
查找特定属性的时候,我们先去这个对象里去找,如果没有的话就去它的原型对象里面去,如果还是没有的话再去向原型对象的原型对象里去寻找...... 这个操作被委托在整个原型链上,这个就是我们说的原型链了。
预解析:
JavaScript引擎在对JavaScript代码进行解释执行之前,会对JavaScript代码进行预解析,在预解析阶段,会将以关键字var和function开头的语句块提前进行处理。
当变量和函数的声明处在作用域比较靠后的位置的时候,变量和函数的声明会被提升到作用域的开头。
function比var级别高
javaScript的语句构成:
值、运算符、表达式、关键词和注释。
JavaScript 值:
JavaScript 语句定义两种类型的值:混合值和变量值。
混合值和变量值:
混合值被称为字面量(literal)。变量值被称为变量