javascript - 变量的赋值情况解惑

查看:134
本文介绍了javascript - 变量的赋值情况解惑的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

第一:如下,按我的理解是函数里面的b引用了外面定义的全局变量b并重新赋值,所以b=2可以理解,而在函数里面重新定义了变量a生成新的作用域,我不理解a的值为undefined的具体思路是怎么来的???

var a, b = 0, 
fn = function(){

var a = b = 2;

};

fn();
console.log(a, b);//(undefined,2)

第二:如下,在函数里面,不是应该先提升变量么,为什么第一个打印出a的值是undefined?

var a = 100;

 function test () {
     console.log(a);//undefined
       
     var a = 200; 
     
     console.log(a);//200  
 }  

 test();

请大神们指点迷津......

解决方案

1.你的a没有赋值自然是undefined,请用 var a=0,b=0;

2.test()下的a会在函数内变量提升,相当于

function test(){
    var a;
    console.log(a);
    a=200;
    console.log(a);
}

这篇关于javascript - 变量的赋值情况解惑的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆