JavaScript基础语法9-作用域

本文深入讲解JavaScript中的作用域概念,包括全局作用域、局部作用域(函数作用域)、块级作用域及其区别,并探讨作用域链的工作原理。

1.作用域

    <script>

        // 1.JavaScript作用域:就是代码名字(变量)在某个范围内起作用和效果

        // 目的: 为了提高程序的可用性,减少命名冲突

        // 2. js的作用域(es6)之前: 全局作用域、局部作用域

        // 3.全局作用域: 整个script标签 或者是一个单独的js文件

        var num = 10;

        console.log(num);

        // 4. 局部作用域(函数作用域): 在函数内部就是局部作用域,这个代码的名字只在函数内部起作用和效果

        function fn(){

            num = 20;

            console.log(num);

        }

        fn();

    </script>

2.变量的作用域

在JavaScript中,根据作用域的不同,变量分为两种:全局变量、局部变量
全局变量

局部变量 

 全局变量和局部变量的区别

    <script>
        // 根据作用域的不同,变量分为两种:全局变量、局部变量
        // 1. 全局变量: 在全局作用域下的变量
        // 注意 如果在函数内部 没有声明直接赋值的变量也属于全局变量
        var num = 10; // num为全局变量
        console.log(num);
        function fn(){
            console.log(num);
        }
        fn();
        // 2. 局部变量:在局部作用域下的变量 就是在函数内部的变量
        // 注意: 函数的形参也可以看做是局部变量
        function fun(){
            var num1 = 10;
            num2 = 20;
        }
        fun();
        // console.log(num1); //num1 is not defined
        console.log(num2);
        // 3.从执行效率来看全局变量和局部变量
        // (1) 全局变量只有浏览器关闭的时候才会销毁,比较占内存资源
        // (2) 局部变量 当程序执行完毕就会销毁,比较节约内存资源 
    </script>

块级作用域 { }    if { }  for { }  (ES6才有的)

3.作用域链

    <script>

        // 作用域链: 内部函数访问外部函数的变量,采取的是链式查找的方式来决定取哪个值

        // 作用域链 采取就近原则

        var num = 10;

        function fn(){  // 外部函数

            var num = 20;

            function fun(){ //内部函数

                console.log(num);

            }

            fun();

        }

        fn();

    </script>

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值