JS函数、arguments、作用域、作用域链、预解析

函数的返回值
返回值语法:
//声明一个带返回值的函数
function 函数名(形参1, 形参2, 形参…){
//函数体
return 返回值;
}
//可以通过变量来接收这个返回值
var 变量 = 函数名(实参1, 实参2, 实参3);

arguments的使用
有函数都内置了一个arguments对象,arguments对象中存储了传递的所有的实参。arguments是一个伪数组,因此及可以进行遍历

函数其它
匿名函数
匿名函数:没有名字的函数
匿名函数如何使用:
将匿名函数赋值给一个变量,这样就可以通过变量进行调用 匿名函数自调用

关于自执行函数(匿名函数自调用)的作用:防止全局变量污染。
自调用函数
匿名函数不能通过直接调用来执行,因此可以通过匿名函数的自调用的方式来执行
(function () {
alert(123);
})();

函数是一种数据类型
函数作为参数
因为函数也是一种类型,可以把函数作为一个函数的参数,在一个函数中调用
如果一个函数作为参数,那么我们说这个参数(函数)可以叫回调函数
函数做为返回值
因为函数是一种类型,所以可以把函数可以作为返回值从函数内部返回,这种用法在后面很常见。
function fn(b) {
var a = 10;
return function () {
alert(a+b);
}
}
fn(15)();

作用域
作用域:变量可以起作用的范围
全局变量和局部变量
全局变量
​在任何地方都可以访问到的变量就是全局变量,对应全局作用域(除了函数以外,其他的任何位置定义的变量都是全局变量)
局部变量
​只在固定的代码片段内可访问到的变量,最常见的例如函数内部。对应局部作用域(函数作用域)
块级作用域
任何一对花括号({和})中的语句集都属于一个块,在这之中定义的所有变量在代码块外都是不可见的,我们称之为块级作用域。在es5之前没有块级作用域的的概念,只有函数作用域,现阶段可以认为JavaScript没有块级作用域

(函数允许访问函数外的数据.
整个代码结构中只有函数可以限定作用域.
作用域规则首先使用提升规则分析
如果当前作用规则中有名字了, 就不考虑外面的名字)

作用域链
只有函数可以制造作用域结构, 那么只要是代码,就至少有一个作用域, 即全局作用域。凡是代码中有函数,那么这个函数就构成另一个作用域。如果函数中还有函数,那么在这个作用域中就又可以诞生一个作用域。 将这样的所有的作用域列出来,可以有一个结构: 函数内指向函数外的链式结构。就称作作用域链。
案例:
function f1() {
function f2() {
}
}

var num = 456;
function f3() {
function f4() {
}
}

预解析
预解析过程:
1.把变量的声明提升到当前作用域的最前面,只会提升声明,不会提升赋值。
2.把函数的声明提升到当前作用域的最前面,只会提升声明,不会提升调用。
3.先提升var,在提升function4

函数内部解析规则
变量提升
变量提升
定义变量的时候,变量的声明会被提升到作用域的最上面,变量的赋值不会提升。
函数提升
JavaScript解析器首先会把当前作用域的函数声明提前到整个作用域的最前面

猜你喜欢

转载自blog.csdn.net/qq_43021088/article/details/82390677