作用域、变量提升和闭包

本文详细讲解了JavaScript中的作用域、变量提升和闭包的概念及原理。作用域包括全局作用域、函数作用域和块级作用域,变量提升涉及函数和变量声明的提升规则。闭包则是函数内部可以访问外部变量的一种机制,用于保护变量不被全局污染。文中通过实例解析了闭包的生成和应用,以及如何避免内存泄漏问题。
摘要由CSDN通过智能技术生成

一、 说明

先浏览题目,判断自己对作用域、变量提升和闭包的掌握情况。然后了解概念和原理,再对照问题检查掌握情况。

二、 题目

  1. 下面代码输出的结果?(函数作用域)
var name = 'window';

console.log(name);

function outer() {
    var name = 'outer';
    console.log(name);

    function inner() {
        console.log(name);
    }

    inner();
}

outer();

第一个name是全局作用域,打印’window’,第二个name是函数作用域,打印’outer’,第三个name是函数作用域,inner里面未定义name因此上溯到outer函数中,打印结果也是’outer’。

  1. 下面代码执行的结果?(块级作用域)
function test() {
    if (true) {
        var a = 'true';
    }
    else {
        var a = 'false';
    }

    console.log(a);
}
test();

function test1() {
    if (true) {
        const a = 'true';
    }
    else {
        const a = 'false';
    }

    console.log(a);
}
test1();

test()执行结果是’true’,因为是函数作用域,在函数内声明的变量都可以访问到。test1()执行结果报错,因为const和let声明的变量定义在块级作用域,只有语句块({}括起来的区域)可以访问到。

  1. 下面代码执行的结果?(变量提升)
function test() {
    console.log(a);
    var a = 1;
    console.log(a);
}
test();

function test1() {
    console.log(a);
    const a = 1;
    console.log(a);
}
test1();

function test2() {
    console.log(inner());
    function inner() {
        return 'inner';
    }
}
test2();

function test3() {
    console.log(inner());
    var inner = function () {
        return 'inner';
    }
}
test3();

function test4() {
    var a = 1;
    function inner() {
        console.log(a);
        var a = 2;
    }
}

写出变量提升后各个函数的等价形式不难得出结果。
test()结果是undefined、1
test1()结果是报错,因为const声明的变量不会提升,a访问不到
test2()结果是’inner’,因为函数声明提升了
test3()结果是报错,因为inner声明提前,但是定义没有提前,所以调用的时候取值是undefined
test4()结果是undefined,因为执行console.log(a)时候先在inner函数作用域内寻找,由于inner内部变量a提升,取值是undefined,因此打印undefined。

  1. 实现一个创建计数器的方法,支持增加计数和获取计数,对比下列两种实现方式。(闭包的应用场景)
/*方法1*/

var count = 0;

function createCounter() {
    function increase() {
        count++;
    }

    function getCount() {
        return count;
    }

    return {
        increase: increase,
        getCount: getCount
    };
}

var counter = createCounter();
counter.increase();

console.log(counter.getCount());
console.log(count);

/*方法2*/

function createCounter() {
    var count = 0;

    function increase() {
        count++;
    }

    function getCount() {
        return count;
    }

    return {
        increase: increase,
        getCount: getCount
    };
}

var counter = createCounter();
counter.increase();

console.log(counter.getCount());
console.log(count);

答案见闭包的概念

  1. 下面各个代码段执行结果?(闭包练习)
// 代码段1
function test() {
    var arr = [];
    for(var i = 0; i <= 5; i++) {
        arr[i] = function () {
            console.log(i);
        };
    }
    return arr;
}

var funcList = test();

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值