目录
1.声明函数的方法
声明函数的方法
三种:函数的声明、函数表达式、Function 构造函数
- (1)函数的声明
function print(s) {
console.log(s);
}
- (2)函数表达式
匿名函数赋值给变量。这时,这个匿名函数又称函数表达式,因为赋值语句的等号右侧只能放表达式。
采用函数表达式声明函数时,function命令后面不带有函数名。如果加上函数名,该函数名只在函数体内部有效,在函数体外部无效。
var print = function(s) {
console.log(s);
};
var print = function x(){
console.log(typeof x);
};
x; // ReferenceError: x is not defined
print(); // function
- (3)Function 构造函数
你可以传递任意数量的参数给Function构造函数,只有最后一个参数会被当做函数体,如果只有一个参数,该参数就是函数体。
var add = new Function(
'x',
'y',
'return x + y'
);
// 等同于
function add(x, y) {
return x + y;
}
- 区别一:
函数声明会被提升,但是函数表达式不会被提升,因为函数表达式还没有被赋值,只是一个未定义变量,当然无法被执行。
function a() {
console.log('函数声明');
}
var b;
a();
b(); // TypeError: b is not a function
b; // 正确
b = function () {
console.log('函数表达式');
}
- 区别二:
函数表达式可以直接加圆括号就可以执行,而函数声明不行;
var print = function (s) {
console.log(s);
}(10); // 10
function (s) {
console.log(s);
}(10); // SyntaxError: function statement requires a name
- 立即执行函数表达式的两种表现:
// 功能上是一致的,如何写凭个人喜好
(function() {})();
(function() {} ());