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

 更新时间:2015年02月15日 09:37:34   投稿:hebedich  
这篇文章主要介绍了浅析javascript中函数声明和函数表达式的区别,需要的朋友可以参考下

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未定义

以上就是本文的全部内容了,希望大家能够喜欢。

相关文章

  • Echarts折线图如何根据容器宽度自适应展示

    Echarts折线图如何根据容器宽度自适应展示

    我们使用vue做项目的时候,常常需要做到echarts图表的自适应,一般是根据页面的宽度做对应的适应,下面这篇文章主要给大家介绍了关于Echarts折线图如何根据容器宽度自适应展示的相关资料,需要的朋友可以参考下
    2022-11-11
  • javascript实现选中复选框后相关输入框变灰不可用的方法

    javascript实现选中复选框后相关输入框变灰不可用的方法

    这篇文章主要介绍了javascript实现选中复选框后相关输入框变灰不可用的方法,涉及javascript针对页面元素属性的相关操作技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • javascript使用正则获取url上的某个参数

    javascript使用正则获取url上的某个参数

    使用indexOf取得?之后的参数,以&使split进行分割成数组,下面展示了一个从url上获取名为MenuCode参数的过程
    2014-09-09
  • js获取浏览器的各种属性

    js获取浏览器的各种属性

    本篇文章主要介绍了js获取浏览器各种属性的相关资料。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-04-04
  • 小程序实现留言板

    小程序实现留言板

    这篇文章主要为大家详细介绍了微信小程序实现留言板,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-11-11
  • JS实现进度条动态加载特效

    JS实现进度条动态加载特效

    这篇文章主要为大家详细介绍了JS实现进度条动态加载特效,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • javascript 选择文件夹对话框(web)

    javascript 选择文件夹对话框(web)

    web程序开发中经常会遇见选择文件夹的时候,这对于web程序员是一件麻烦的事情,由于本地安全限制JS不能访问本地文件,所以选择文件夹一般都避而不谈,笔者在写一个程序的时候也遇见了同样的问题,开始尝试使用JS来遍历文件,结果都没有成功
    2009-07-07
  • JavaScript实现忘记密码功能的示例代码

    JavaScript实现忘记密码功能的示例代码

    这篇文章主要为大家详细介绍了如何使用HTML、CSS和JavaScript实现一个完整的忘记密码功能,文中的示例代码讲解详细,需要的可以参考一下
    2024-01-01
  • 总结分享10 个超棒的 JavaScript 简写技巧

    总结分享10 个超棒的 JavaScript 简写技巧

    这篇文章主要总结分享10 个超棒的 JavaScript 简写技巧,有合并数组、克隆数组、解构赋值、模板字面量等技巧,需要的朋友可以参考一下
    2022-06-06
  • JavaScript 中断请求几种方案详解

    JavaScript 中断请求几种方案详解

    这篇文章主要介绍了JavaScript 中断请求几种方案详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09

最新评论