深入函数
函数介绍
- 函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块。
- 通过函数可以封装任意多条语句,而且可以在任何地方任何时候调用执行。
- 构成函数主体的 JS 代码在定义之时并不会执行,只会调用该函数,它们才会执行。
函数声明
声明方式
- function 函数声明
- function 命令声明的代码区块,就是一个函数。
- function 命令后者是函数名,函数名后面是一对圆括号,里面是传入函数的参数。函数体放在大括号里面。
- 使用函数声明的函数在 JS 预解析时具有提升效果,在执行代码之前会先读取函数声明。
- function 函数表达式
- 形式类似变量赋值语句,即创建一个函数并将它赋值给变量。
- 此时创建的函数叫做匿名函数,匿名函数的 name 属性是空字符串。
- 函数的表达式需要在语句的结尾加上分号,表示语句
结束。
- Function 构造函数
- 使用 Function 构造函数, Function 构造函数接受三个参数,除了最后一个参数是函数的“函数体”,其他参数都是函数的参数。
- Function 构造函数可以不使用 new 命令,返回结果完全一样。
- 重复声明
如果同一个函数被多次声明,后面的声明就会覆盖前面的声明。
第一等公民
- JavaScript 语言将函数看作一种值,与其它值(数值、字符串、布尔值等等)地位不同。
- 可以把函数赋值给变量和对象的属性,也可以当作参数传入其他函数,或者作为函数的结果返回。
- 函数存在一个属性 length: 函数定义形式参数的个数。
函数调用
- 普通函数调用
- 命名函数
调用函数时,要使用圆括号运算符。圆括号之中,可以加入函数的参数。 - 匿名函数
赋值变量调用
直接调用 - 函数可以调用自身,这样的行为称之为递归。
- 对象方法调用
- 一个无法无非是个保存在一个对象的属性里的 JS 函数。
- 对象.方法名()
适用于合法标识符 - 对象[方法名]()
合法标识符
非法标识符
变量 - 链式调用
return this;
- 构造函数调用
- 如果函数或者方法调用之前带有 new 关键字,它就构成构造函数调用。
如果构造函数调用在圆括号内包含一组实参列表,这和函数调用和方法调用是一致的。
如果构造函数没有形参,JS 构造函数调用的语法是允许省略实参列表和圆括的。 - 构造函数通常不使用 return 关键字,它们通常初始化新对象,当构造函数的函数体执行完毕时,它会显示返回。
- 间接调用
- JS 函数也是对象,和其他 JS 对象一样,函数对象也可以包含方法,其中的两个方法call() 和 apply() 可以用来间接地调用对象。
- call() 方法使用它自有的实参列表作为函数的实参
- apply() 方法要求以数组的形式传入参数
函数参数
- 函数运行的时候,有时需要提供外部数据,不同的外部数据会得到不同的结果,这种外部数据就叫做参数
- JS 函数定义是不会为参数规定数据类型
- JS 函数调用时不会对参数值进行任何检查
- arguments 对象
- 在函数体内可以通过 arguments 对象来访问这个参数类
- arguments 对象只有在函数体内部,才可以使用。
- 通过 arguments 对象的 length 属性,可以判断函数调用时到底带几个参数。
- 没有传递值的命名参数将自动被赋予 undefined 值。
- arguments 对象带有一个 callee 属性,返回它所对应的原函数。
函数返回值
- return 语句
- 函数体内部的 return 语句,表示返回。
- 任何函数在任何时候都可以通过 return 语句后跟要返回的值来实现返回值。
- 未指定返回值的函数返回的是一个特殊的 undefined 值。