JavaScript定义函数的两种方式

   定义函数的方式有两种:一种是函数声明,另一种就是函数表达式;

      1.1 函数声明

function functionName(arg){
     //函数体
}

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

helloworld(); //在代码执行之前会先读取函数声明
function helloworld(){
   console.log("hello world");
}

     1.2 函数表达式

var functionName=function(arg){
      //函数体
}

      这种形式看起来好像是常规的变量赋值语句,即创建一个函数并将它赋值给变量functionName。这种情况下创建的函数叫做匿名函数。因为function关键字后面没有标识符。

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

helloworld(); //错误,还未赋值,函数不存在

var helloworld=function(){
    console.log("hello world");
}

       有了函数表达式,我们就可以动态给函数表达式赋值了;如下面代码:

复制代码

var helloworld; //声明
if(condition){ //条件
   helloworld=function(){ //赋值
       console.log("hello world"); 
   }
}
else{
    helloworld=function(){ //赋值
       console.log("你好,世界");
    }
}

复制代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值