javascript 变量提升

javascript是一种弱类型、动态的、解释性的脚本语言

例1:

<script type="text/javascript">

    console.log(a);//输出结果 undefined
    var a=10;
</script>
#以上代码输出 undefined 
#原因:  变量提升(把变量声明提升到当前执行环境的最顶端) 
#上段代码相当于: 
        var a;  
        console.log(a);//由于未赋值 所以输出undefined 
        a=10;

例2:

    foo();
    function foo(){
        console.log("aaa");
    }

#结果输出: aaa 
#原理:函数声明提升 (函数声明提升直接把整个函数提到执行环境的最顶端)
#相当于:
    function foo(){
        console.log("aaa");
    }

    foo();

#变量提升只提升变量名 而函数提升会提升整个函数体  注意:函数提升在变量提升上面。

例3:

foo();
    var foo = function(){
        console.log("aaa");
    }

#运行结果是: foo is not a function
#原因: 还是进行了变量提升 
#相当于:
var foo;
console.log(foo);  //undefined
foo(); //foo is not a function
 foo = function(){
        console.log("aaa");
    }

#上面代码输出undefined  是因为变量提升后并没有赋值因此输出undefined

#输出foo is not a function  原因是:js解析遇到 foo()时会默认当做函数来解析 

例4:

console.log(foo);
    var foo=10;
    console.log(foo);
    function foo(){
        console.log(10);
    }
    console.log(foo);

输出结果: 
f function(){
    console.log(10);
}
10
10
相当于:
function foo(){
        console.log(10);
    }
var foo;
console.log(foo);
foo=10;
console.log(foo);
console.log(foo);

#注意: 函数提升在变量提升上面,第一个console.log(foo);为什么会输出函数题呢,原因在于 var foo; #并未有赋值只是声明,因此他会调用上面的值

#例如:
var b=10;
b=10;
console.log(b); //10 输出上一个值不会输出undefined123

#但是更改后:

var b=10;
b=20;
console.log(b); //20 输出20不是上一个值

注意

  • javascript 仅提升声明不提升初始化

  • 关于变量提升,一定要注意细心思考一下,还有就是要牢记,函数提升在变量提升之上

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值