浅析javascript中函数声明和函数表达式的区别

作者:hebedich 时间:2024-05-09 10:33:14 

javascript中声明函数的方法有两种:函数声明式和函数表达式.

区别如下:

1).以函数声明的方法定义的函数,函数名是必须的,而函数表达式的函数名是可选的.

2).以函数声明的方法定义的函数,函数可以在函数声明之前调用,而函数表达式的函数只能在声明之后调用.

3).以函数声明的方法定义的函数并不是真正的声明,它们仅仅可以出现在全局中,或者嵌套在其他的函数中,但是它们不能出现在循环,条件或者try/catch/finally中,而

    函数表达式可以在任何地方声明.

下面分别用两种方法定义函数:


 //函数声明式
 function greeting(){
       console.log("hello world"); 
 }
 //函数表达式
 var greeting = function(){
     console.log("hello world");
 }

下面一个有趣的javascript:


 function f() { console.log('I am outside!'); }
 (function () {
   if(false) {
     // 重复声明一次函数f
     function f() { console.log('I am inside!'); }
   }
   f();
 }());

会输出什么呢?第一反应应该是"I am outside"吧.  结果在chrome中输出"I am inside",IE11直接报错,firefox低一点的版本输出"I am outside"...

chrome输出的结果很明确的反应了用函数声明式声明的函数的特点--函数在声明之前就可以调用.

IE报错显示缺少对象,因为函数声明在了条件里,违背了函数声明式的原则.

函数表达式的作用域:

如果函数表达式声明的函数有函数名,那么这个函数名就相当于这个函数的一个局部变量,只能在函数内部调用,举个栗子:


 var f = function fact(x) {
                 if (x <= 1)
                     return 1;
                 else
                     return x*fact(x-1);
                 };
                 alert(fact());   // Uncaught ReferenceError: fact is not defined

fact()在函数内部可以调用,在函数外部调用就会报错:fact未定义

标签:javascript,函数声明,函数表达式
0
投稿

猜你喜欢

  • Python的Django框架中TEMPLATES项的设置教程

    2022-09-23 03:16:09
  • Oracle中PL/SQL复合数据类型

    2024-01-22 07:17:47
  • asp生成不需要数据库的中奖码

    2008-07-18 12:31:00
  • Python采集王者皮肤图片实战示例

    2021-08-02 12:09:23
  • golang validator库参数校验实用技巧干货

    2024-04-23 09:38:17
  • Python进阶学习修改闭包内使用的外部变量

    2023-04-09 01:23:04
  • 详解用python -m http.server搭一个简易的本地局域网

    2023-09-29 13:03:34
  • Vue.js实现一个todo-list的上移下移删除功能

    2024-04-26 17:38:32
  • mysql 5.1版本修改密码及远程登录mysql数据库的方法

    2024-01-17 15:38:02
  • MySQL不支持INTERSECT和MINUS及其替代方法

    2024-01-14 15:09:11
  • 使用Python绘制空气质量日历图

    2023-06-20 12:19:21
  • 原生JS与jQuery编写简单选项卡

    2024-04-30 09:52:52
  • python使用matplotlib绘制折线图

    2021-08-23 05:12:53
  • Python assert语句的简单使用示例

    2023-06-12 16:38:58
  • php+mysql删除指定编号员工信息的方法

    2024-06-05 09:40:28
  • 微信小程序控制台提示warning:Now you can provide attr "wx:key" for a "wx:for" to improve performance解决方法

    2024-04-18 09:42:40
  • Python打包工具PyInstaller的安装与pycharm配置支持PyInstaller详细方法

    2022-05-20 06:36:55
  • 简述php环境搭建与配置

    2023-11-15 09:08:28
  • 1秒50万字!js实现关键词匹配

    2024-05-02 16:18:04
  • pandas中apply和transform方法的性能比较及区别介绍

    2023-07-18 22:23:40
  • asp之家 网络编程 m.aspxhome.com