JS的四次元口袋:函数声明和函数表达式

函数声明和函数表达式

函数是对象,因此函数名实际上也是一个指向函数对象的指针,不会与某个函数进行绑定。也就是说js中没有函数重载的概念。

1、函数的定义

  • 函数声明
function sum(num1.num2){
    return num1 + num2;
}
  • 函数表达式

使用函数表达式可以在function关键字后不使用函数名,通过变量sum即可调用。当然要注意函数末尾有一个分号,和声明变量一样。

var sum = function(num1,num2){
    return num1 + num2;
};
  • Function构造函数(不建议使用)

不建议使用,可读性太差,而且会导致两次解析(js解析和传入函数的字符串解析)

var sum = new Function("num1","num2","return num1 + num2");

2、函数声明和函数表达式的区别

  • 函数声明必须有函数名,而函数表达式可以不使用函数名。
  • 函数声明整体会变量提升到当前作用域的顶部,而函数表达式只有变量名提升到当前作用域顶部,因为本身就是通过声明变量一样的使用。
  • 函数声明定义的函数可以在函数声明前调用,而函数表达式定义的函数必须在函数声明之后调用。
  • 函数声明不是一个完整的语句,所以不能出现在if-else,for循环,finally,try catch语句以及with语句中,而函数表达式可以。

函数声明:(可以在函数声明前调用)

console.log(sum(1,2)) //3
function sum(num1.num2){
    return num1 + num2;
}

函数表达式:(必须在函数声明之后调用,否则报错)

console.log(sum(1,2))//报错
var sum = function(num1,num2){
    return num1 + num2;
};
console.log(sum(1,2))//3

发布了78 篇原创文章 · 获赞 5 · 访问量 8285

猜你喜欢

转载自blog.csdn.net/qq_36789311/article/details/105231157