JavaScript中函数表达式和函数声明及函数声明与函数表达式的不同


Posted in Javascript onNovember 15, 2015

函数表达式和函数声明

在ECMAScript中,创建函数的最常用的两个方法是函数表达式和函数声明,两者期间的区别是有点晕,因为ECMA规范只明确了一点:函数声明必须带有标示符(Identifier)(就是大家常说的函数名称),而函数表达式则可以省略这个标示符:

函数声明:

function 函数名称 (参数:可选){ 函数体 }

函数表达式:

function 函数名称(可选)(参数:可选){ 函数体 }

所以,可以看出,如果不声明函数名称,它肯定是表达式,可如果声明了函数名称的话,如何判断是函数声明还是函数表达式呢?ECMAScript是通过上下文来区分的,如果function foo(){}是作为赋值表达式的一部分的话,那它就是一个函数表达式,如果function foo(){}被包含在一个函数体内,或者位于程序的最顶部的话,那它就是一个函数声明。

function foo(){} // 声明,因为它是程序的一部分
 var bar = function foo(){}; // 表达式,因为它是赋值表达式的一部分
 new function bar(){}; // 表达式,因为它是new表达式
 (function(){
  function bar(){} // 声明,因为它是函数体的一部分
 })();

还有一种函数表达式不太常见,就是被括号括住的(function foo(){}),他是表达式的原因是因为括号 ()是一个分组操作符,它的内部只能包含表达式,我们来看几个例子:

  function foo(){} // 函数声明
  (function foo(){}); // 函数表达式:包含在分组操作符内

命名函数表达式

提到命名函数表达式,理所当然,就是它得有名字,前面的例子var bar = function foo(){};就是一个有效的命名函数表达式,但有一点需要记住:这个名字只在新定义的函数作用域内有效,因为规范规定了标示符不能在外围的作用域内有效:

var f = function foo(){
  return typeof foo; // foo是在内部作用域内有效
 };
 // foo在外部用于是不可见的
 console.log(typeof foo); // "undefined"
 console.log(f()); // "function"
var f = function foo(){
return foo; // foo是在内部作用域内有效
};
// foo在外部用于是不可见的
console.log(typeof foo); // "undefined"
console.log( f()==f); // "function"
console.log(f.name);//foo

既然,这么要求,那命名函数表达式到底有啥用啊?为啥要取名?

正如我们开头所说:给它一个名字就是可以让调试过程更方便,因为在调试的时候,如果在调用栈中的每个项都有自己的名字来描述,那么调试过程就太爽了,感受不一样嘛。

ps:JS中函数声明与函数表达式的不同

Js中的函数声明是指下面的形式:

function functionName(){ 
}

这样的方式来声明一个函数,而函数表达式则是类似表达式那样来声明一个函数,如:

var functionName = function(){ 
}

可能很多朋友在看到这两一种写法时会产生疑惑,这两种写法差不多,在应用中貌似也都是可行的,那他们有什么差别呢?

 事实上,js的解析器对函数声明与函数表达式并不是一视同仁地对待的。对于函数声明,js解析器会优先读取,确保在所有代码执行之前声明已经被解析,而函数表达式,如同定义其它基本类型的变量一样,只在执行到某一句时也会对其进行解析,所以在实际中,它们还是会有差异的,具体表现在,当使用函数声明的形式来定义函数时,可将调用语句写在函数声明之前,而后者,这样做的话会报错。

Javascript 相关文章推荐
jQuery替换字符串(实例代码)
Nov 13 Javascript
Node.js中安全调用系统命令的方法(避免注入安全漏洞)
Dec 05 Javascript
Fullpage.js固定导航栏-实现定位导航栏
Mar 17 Javascript
javascript创建对象的几种模式介绍
May 06 Javascript
两种js监听滚轮事件的实现方法
May 13 Javascript
使用jQuery ajaxupload插件实现无刷新上传文件
Apr 23 jQuery
vue-cli配置环境变量的方法
Jul 09 Javascript
微信小程序滑动选择器的实现代码
Aug 10 Javascript
Node.js JSON模块用法实例分析
Jan 04 Javascript
Vue.js项目实战之多语种网站的功能实现(租车)
Aug 07 Javascript
Vue.js使用axios动态获取response里的data数据操作
Sep 08 Javascript
vue常用高阶函数及综合实例
Feb 25 Vue.js
浅谈JavaScript中的对象及Promise对象的实现
Nov 15 #Javascript
javascript 中的 delete及delete运算符
Nov 15 #Javascript
详解JavaScript函数对象
Nov 15 #Javascript
javascript中window.open在原来的窗口中打开新的窗口(不同名)
Nov 15 #Javascript
深入浅析JavaScript中prototype和proto的关系
Nov 15 #Javascript
apply和call方法定义及apply和call方法的区别
Nov 15 #Javascript
JavaScript和HTML DOM的区别与联系及Javascript和DOM的关系
Nov 15 #Javascript
You might like
php json_encode值中大括号与花括号区别
2013/09/30 PHP
php+ajax导入大数据时产生的问题处理
2014/06/11 PHP
基于ThinkPHP+uploadify+upload+PHPExcel 无刷新导入数据
2015/09/23 PHP
ThinkPHP5.0多个文件上传后找不到临时文件的修改方法
2018/07/30 PHP
PhpStorm 2020.3:新增开箱即用的PHP 8属性(推荐)
2020/10/30 PHP
jQuery阻止冒泡和HTML默认操作
2010/11/17 Javascript
处理文本部分内容的TextRange对象应用实例
2014/07/29 Javascript
Jquery中扩展方法extend使用技巧
2014/08/24 Javascript
用C/C++来实现 Node.js 的模块(二)
2014/09/24 Javascript
AngularJS 基础ng-class-even指令用法
2016/08/01 Javascript
微信小程序 for 循环详解
2016/10/09 Javascript
利用Angularjs中模块ui-route管理状态的方法
2016/12/27 Javascript
微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(一)
2017/05/11 Javascript
node.js 利用流实现读写同步,边读边写的方法
2017/09/11 Javascript
微信小程序实现循环动画效果
2018/07/16 Javascript
Vue三种常用传值示例(父传子、子传父、非父子)
2018/07/24 Javascript
vue.js 实现评价五角星组件的实例代码
2018/08/13 Javascript
vue项目中使用scss的方法步骤
2019/05/16 Javascript
通过原生vue添加滚动加载更多功能
2019/11/21 Javascript
vue实现购物车案例
2020/05/30 Javascript
JS使用setInterval计时器实现挑战10秒
2020/11/08 Javascript
[01:09:10]NB vs Liquid Supermajor小组赛 A组胜者组决赛 BO3 第一场 6.2
2018/06/04 DOTA
python利用拉链法实现字典方法示例
2017/03/25 Python
Python生成随机密码的方法
2017/06/16 Python
Python元组拆包和具名元组解析实例详解
2018/03/26 Python
python使用多进程的实例详解
2018/09/19 Python
python 通过类中一个方法获取另一个方法变量的实例
2019/01/22 Python
Django自定义用户登录认证示例代码
2019/06/30 Python
python 调试冷知识(小结)
2019/11/11 Python
python将unicode和str互相转化的实现
2020/05/11 Python
使用canvas压缩图片上传的方法示例
2020/02/07 HTML / CSS
TripAdvisor土耳其网站:全球知名旅行社区,真实旅客评论
2017/04/17 全球购物
德国大型和小型家用电器网上商店:Energeto
2019/05/15 全球购物
个人自荐书
2013/12/20 职场文书
《爱的教育》读书心得
2014/11/08 职场文书
2016年党员创先争优公开承诺书
2016/03/25 职场文书