美文网首页
函数表达式

函数表达式

作者: 懒学者爱学习 | 来源:发表于2017-09-26 10:00 被阅读0次

定义函数的方式有两种:

(1)函数声明

function functionName(arg0, arg1, arg2) {

//函数体

}

首先是 function 关键字,然后是函数的名字,这就是指定函数名的方式。Firefox、Safari、Chrome和 Opera 都给函数定义了一个非标准的 name 属性,通过这个属性可以访问到给函数指定的名字。这个属性的值永远等于跟在 function 关键字后面的标识符。

//只在 Firefox、Safari、Chrome 和 Opera 有效

alert(functionName.name); //"functionName"

关于函数声明,它的一个重要特征就是函数声明提升(function declaration hoisting),意思是在执行代码之前会先读取函数声明。这就意味着可以把函数声明放在调用它的语句后面。

sayHi();

function sayHi(){

alert("Hi!");

}

(2)函数表达式

var functionName = function(arg0, arg1, arg2){

//函数体

};

这种形式看起来好像是常规的变量赋值语句,即创建一个函数并将它赋值给变量 functionName 。这种情况下创建的函数叫做匿名函数(anonymous function),因为 function 关键字后面没有标识符。匿名函数有时候也叫拉姆达函数。)匿名函数的 name 属性是空字符串。

函数表达式与其他表达式一样,在使用前必须先赋值。以下代码会导致错误。

sayHi(); //错误:函数还不存在

var sayHi = function(){

alert("Hi!");

};

理解函数提升的关键,就是理解函数声明与函数表达式之间的区别。例如,执行以下代码的结果可能会让人意想不到。

//不要这样做!

if(condition){

function sayHi(){

alert("Hi!");

}

} else {

function sayHi(){

alert("Yo!");

}

}

表面上看,以上代码表示在 condition 为 true 时,使用一个 sayHi() 的定义;否则,就使用另一个定义。实际上,这在 ECMAScript 中属于无效语法,JavaScript 引擎会尝试修正错误,将其转换为合理的状态。但问题是浏览器尝试修正错误的做法并不一致。大多数浏览器会返回第二个声明,忽略condition ;Firefox 会在 condition 为 true 时返回第一个声明。因此这种使用方式很危险,不应该出现在你的代码中。

不过,如果是使用函数表达式,那就没有什么问题了。

//可以这样做

var sayHi;

if(condition){

sayHi = function(){

alert("Hi!");

};

} else {

sayHi = function(){

alert("Yo!");

};

}

这个例子不会有什么意外,不同的函数会根据 condition 被赋值给 sayHi 。


相关文章

  • 函数与作用域

    函数声明和函数表达式有什么区别 函数声明 函数表达式 区别 函数表达式结束后需要加;表示声明变量结束。 函数表达式...

  • 函数

    函数声明和函数表达式有什么区别 函数声明 函数表达式 函数声明和函数表达式的区别: 函数声明必须给定函数名称,函数...

  • JS一些基础小知识

    函数表达式 函数声明:function a(){ ... }函数表达式:var a = function() {....

  • Kotlin(一)

    函数 函数定义 默认参数 //匿名函数 //表达式函数 //(Int,Int)->Int //lambda表达式,...

  • JavaScript 函数

    函数声明和函数表达式 函数声明和函数表达式都是创建函数的方法; 函数声明会触发函数提升,而函数表达式不会;前置不前...

  • js ------ 函数声明和函数表达式

    js创建对象几种方式 js 函数声明 和 函数表达式函数声明 函数表达式 函数表达式: 下面的函数都会直接运行

  • 学习内容

    函数 顶层函数 扩展函数 可变函数 局部函数 组件函数 中缀调用 let函数 lambda表达式 表达式 解构声明...

  • 函数声明语句与函数表达式函数表达式中的有名函数表达式 typeof知识点 函数自带参数arguments delete

  • 函数与作用域

    函数声明和函数表达式有什么区别 函数声明function声明一个函数 函数表达式函数表达式不是以function开...

  • 进阶3

    函数声明和函数表达式 函数声明:function functionName(){}  函数表达式:var fn =...

网友评论

      本文标题:函数表达式

      本文链接:https://www.haomeiwen.com/subject/zeyfextx.html