1.采用函数表达式声明函数时,function
命令后面不带有函数名。如果加上函数名,该函数名只在函数体内部有效,在函数体外部无效。
var print = function x(){
console.log(typeof x);
};
x// ReferenceError: x is not defined
print()// function
2.return
语句不是必需的,如果没有的话,该函数就不返回任何值,或者说返回undefined
。
3.JavaScript 语言将函数看作一种值。
4.函数的属性:
name
属性返回函数的名字。
length
属性返回函数预期传入的参数个数。
function f1() {}
f1.name // "f1"
var f2 = function () {};
f2.name // "f2"
var f3 = function myName() {};
f3.name // 'myName'
function f(a, b) {}
f.length // 2
5.函数的toString()
方法返回一个字符串,内容是函数的源码。
function f() {
a();
b();
c();
}
f.toString()
// function f() {
// a();
// b();
// c();
// }
6.对于var
命令来说,局部变量只能在函数内部声明,在其他区块中声明,一律都是全局变量。
7.函数本身的作用域与变量一样,就是其声明时所在的作用域,与其运行时所在的作用域无关。
8.如果一定要省略靠前的参数,只有显式传入undefined
。
function f(a, b) {
return a;
}
f(undefined, 1) // undefined
9.函数参数如果是原始类型的值(数值、字符串、布尔值),传递方式是传值传递(passes by value)。这意味着,在函数体内修改参数值,不会影响到函数外部。
10.函数参数如果是复合类型的值(数组、对象、其他函数),传递方式是传址传递(pass by reference)。也就是说,传入函数的原始值的地址,因此在函数内部修改参数,将会影响到原始值。
11.arguments
对象可以在函数体内部读取所有参数。
- 正常模式下,
arguments
对象可以在运行时修改。 - 严格模式下,修改
arguments
对象不会影响到实际的函数参数。
arguments
对象的length
属性,可以判断函数调用时到底带几个参数。
var f = function (one) {
console.log(arguments[0]);
console.log(arguments[1]);
console.log(arguments[2]);
}
f(1, 2, 3)
// 1
// 2
// 3
function f() {
return arguments.length;
}
f(1, 2, 3) // 3
f(1) // 1
f() // 0
12.立即调用的函数表达式(IIFE)。函数定义后立即调用的解决方法,就是不要让function
出现在行首,让引擎将其理解成一个表达式。最简单的处理,就是将其放在一个圆括号里面。
通常情况下,只对匿名函数使用这种“立即执行的函数表达式”。它的目的有两个
- 是不必为函数命名,避免了污染全局变量。
-
IIFE 内部形成了一个单独的作用域,可以封装一些外部无法读取的私有变量。
13.eval
命令接受一个字符串作为参数,并将这个字符串当作语句执行。
eval('var a = 1;');
a // 1