函数定义: 函数可以封装任意多条语句,可以在任何地方或时候调用执行
创建函数:
第一种: 函数声明
function 函数名() {
执行代码
}
第二种函数表达式
var fn = function () {
执行代码
}
第三种: 实例化函数
var fn = new Function('执行代码');
第四种:自执行函数(拉姆达函数)
(function () {
执行代码
})()
调用函数
fn();
函数声明与函数表达式的区别
解析器会率先读取函数声明,并使其在执行任何代码之前可用
函数表达式,则必须等到解析器执行到它所在的代码行,才会真正被解释执行
本质是变量与函数的提升
函数无重载
在ECMAScript中定义了两个函数名相同的函数,则名字只属于后定义的函数(后面定义的函数会覆盖前面定义的函数)
函数的参数
-
形参
形式上的参数: 命名的参数只提供的便利,但不是必需的function fn(x, y, z) { var x, y, z; console.log(x, y, z); // 1, 2 undefined } 形参个数: 函数名.length fn(1, 2); // 1, 2 是实参
-
实参
实际的参数: 调用函数时传入有值的参数 实参的个数: 实参集合中(argument.length);
-
arguments
arguments对象:实参的类数组,从而获取传递给函数的每一个参数 arguments对象的长度是由传入的参数个数决定的,不是由定义函数时的命 名参数的个数决定的 也有length属性,代表传入了几个参数 arguments.callee: 指的是当前执行的函数
-
return 返回值
1. 当一个函数没有返回值时候,默认返回undefined 2. 当使用 return 返回值; 3. return 之后的语句不会执行,return终止了函数执行
-
局部变量和全局变量
局部变量: 局部作用域下声明的变量 全局变量:全局作用域下声明的变量
变量提升和函数体提升
在js代码执行之前:解析器会将变量名以及函数声明的函数体提升到最顶端
-
函数提升:
如果函数名相同的两个函数: 前面函数会覆盖后面的函数 (导致我们的函数无重载的概念) -
函数名和变量名相同:函数优先覆盖变量
网友评论