effective js-15-函数提升

 

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>js-函数提升</title>

</head>

<body>

 

<script>

window.onload = function() {

var a = 2;

/* function show() {

       alert("奇数");

   };

   function show() {

       alert("偶数");

   }; */ // 函数提升:是整个函数的提升

/***不正常弹出**/

if(a % 2 == 1) {

   function show() {

       alert("奇数");

   };

} else {

   function show() {

       alert("偶数");

   };

}

 

show(); // 总会弹出"偶数",跟 a 的值无关

 

/***正常弹出**/

if(a % 2 == 1) {

   var show2 = function() {

       alert("奇数");

   };

} else {

   var show2 = function() {

       alert("偶数");

   };

}

 

show2(); // 正常弹出奇偶数,此种写法是变量声明的提升

 

};

</script>

 

<p>

理解两点:

1. 变量的提升,只提升变量的声明,赋值留在原地

2. 函数的提升,是整个函数声明的提升

</p>

 

</body>

</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值