03-js提升与闭包练习题

本文通过14个案例详细解析JavaScript中的变量提升、函数提升和闭包的概念及应用,包括变量作用域、函数调用、闭包的形成与作用等关键知识点,帮助读者深入理解JavaScript的基础语法。
摘要由CSDN通过智能技术生成

js变量、函数提升和闭包相关练习题

案例01

1.代码
<script>
    var a = 1;
    var obj = { name:"wangcai" };
    function f() {
        var a2 = a;
        obj2 = obj;
        a2 = a;
        obj.name = "xiaoqiang";
    }
    f();
    console.log(a);
    console.log(obj);
</script>
2.运行结果

在这里插入图片描述

3.原理

在这里插入图片描述

解析:全局变量中,var a;var obj;函数f()进行了提升,程序执行后a的值为 1,obj的值为name:“wangcai”。在函数内部定义一个变量a2,将全局变量a的值赋值给a2,接着把全局变量obj的值赋值给全局变量(VO)obj2,因为a2是函数内部的局部变量,a2的值变为1,但是全局变量中的a没有发生改变。在函数内部,obj将内部的变量修改为"xiaoqiang",最终输出结果为1 {name:“xiaoqiang”}.

案例02

1.代码
<script>
    var arr = [11,22];
    function f(ary) {
        console.log(ary);
        ary[0] = 100;
        ary = [666];
        ary[0] = 0;
        console.log(ary);
    }
    f(arr);
    console.log(arr)
</script>
2.运行结果

在这里插入图片描述

3.原理

在这里插入图片描述

解析:程序编译前,arr、函数f(ary)进行提升,程序执行之后arr = [11,22]。调用函数时,函数内部传入参数ary,ary,所以首先输出ary的值。接着数组的第一个数赋值为100,即将数组内11改为100。当运行到ary = [666]时,ary数组开辟了新空间,得到了新的地址,这时ary的值为[666],紧接着ary[0]=0,把666数值修改为0。这时的输出结果为0。arr是全局变量,存储在EC(G)的VO中,所以arr的输出结果为[100,22]。

案例03

1.代码
<script>
    var a = 1;
    var b = 1;
    function f() {
        console.log(a, b)
        var a = b = 2;
        console.log(a, b)
    }
    f();
    console.log(a, b)
</script>

2.运行结果

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值