JS 变量提升、函数名提升、变量和函数结合的提升

一、变量的提升

1、使用var 关键字声明的变量会提升到代码的头部  变量提升
   例子:
      console.log(num);//undefined
      var num = 100;
      console.log(num);//100
      var x;
      console.log(x);//undefined
2、不使用var关键字声明的变量是全局变量 对
   注意使用环境:如果声明在函数内部,则函数执行后才可以调用
                否则,报错。     
   例子:
     function getValue(){
         var num = 100;
         x = 200;//全局变量
     }
     getValue();
   //  console.log(num);
     console.log(x);

二、函数名的提升:使用function声明的函数会提前到代码的头部

1、function 函数名(){}
    showMessage();
    function showMessage(){
        console.log('呵呵');//呵呵
    }
2、var 标识符 = function(){}
    var func1 = function () {
        console.log('呵呵呵');//呵呵呵
    };
    func1();
3、var func3 = new Function(形参1,形参2...,函数体)    
    func2();
    var func2 = new Function('console.log("呵呵呵呵")');//TypeError: func2 is not a function

三、函数和变量结合的提升

1、使用var关键字声明的变量会提升到 当前作用域的头部
2、变量查找值的过程:
  ①首先在当前变量所在作用域查找;
   没有找到,去上一层作用域查找;
   还没有找到,再去上一层查找;
   直到找到全局作用域。
  ②在任何一层找到该数据 则立即返回值;
  ③如果一直找到全局作用域 还没有发现该值
   那么 如果变量没有声明过 报错 XX is not defined
        如果变量声明过   undefined
  ④一般把此变量的查找过程称为 作用域链
   */
  console.log(c);
  var c = 200;
  var num = 100;
  function showValue() {
      //var num;
      console.log('showValue', num);//100  undefined
     // var num = 200;
      function show1() {
          //var num
          console.log('show1', XX);//200 100 undefined
          var num = 100;
      }
      show1();
  }
  showValue();

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值