---恢复内容开始---
1.函数 关键字function
复习
var 是js的关键字,用于声明变量,声明在内存模块完成,定义(=)是在执行模块完成。
var可以在内存模块提前(js代码执行前)完成所有变量提升这个功能。
因为a没有带var,所以不存在变量提升,浏览器会把他当成window的属性。
function也是js的关键字,用于声明和定义函数的,声明和定义都在内存模块完成了。
function也是内存模块提前完成,所以有函数提升这个功能。
变量提升和函数提升 都叫预解释。都是浏览器的。
2.函数的定义:函数:具有一定功能的代码块。
函数是通过function定义的,function后跟的是函数名。
结构语法
function(){}
通过上图我们可以发现,内存模块只存在ver的变量名。而存在function整块代码块,因为声明
和定义同时完成的。
函数结构的注意的
函数定义 通过function 定义 function fn(){}
函数定义的四种方式
1.声明式定义 function fn(){}
2.表达式式定义 var an=function(){} 匿名函数
3.自调用
定义和调用头同时完成。
4.通过 对象的形式 var as=new function(){}
函数调用 函数名() fn()
函数最大的优势 会形成一个独立的模块,可以按需使用,可以重复使用。
按需使用 可以提升性能 重复使用 减少代码冗余。
函数调用的过程
函数执行时会形成一个自己的私有作用域。最大的作用域是window(全局作用域)
然后执行函数里面的代码块。
案例分析
分析图
作用域链:函数内部的变量被使用时,首先会在自己的私有作用域下查找是否有这个变量,有就直接使用,没有就会向他的上一级查找,父级就使用父级的,父级没有就会以此继续向上查找直到window为止,window有就使用没有就是is not defined 。 这种查找机制我们叫作用域链。
分析图
函数归谁,跟她在那调用没有关系,而是在哪定义有关。
函数递归:函数内部调用自己。
break和function运算
break终止单前程序
continue跳出当前的程序 ,执行下一个。
break和function只能用在循环语句中。如果条件语句想使用break只能使用return。
return 返回的
每个函数都有一个返回值,如果函数人为了,返会什么就是什么。
如果没有人为返回,结果是undefined。并且后面的代码不在执行了。
案例分析
函数内部的return 不影响函数内部的预解释。
函数内外的变量
函数外的变量叫全局变量,函数内的变量叫私有变量。
看变量归谁,看他在那个作用域下声明。
私有变量的种类
1.在私有作用域的声明的。
2.通过函数传参的叫私有变量。
函数传参 argument 参数
function fn(a,b,c,d){} 将a b c d 叫参数
形参 定义上的参数
实参 执行上的参数
console.dir(fn)
---恢复内容结束---