JS作用域

js的作用域

作用域说明:一般理解指一个变量的作用范围

  1. 全局作用域
    (1) 全局作用域在页面打开时被创建,页面关闭时被销毁
    (2) 编写在script标签中的变量和函数,作用域为全局,在页面的任意位置都可以访问到
    (3)在全局作用域中有全局对象window,代表一个浏览器窗口,由浏览器创建,可以直接调用
    (4) 全局作用域中声明的变量和函数会作为window对象的属性和方法保存

  2. 函数作用域
    (1)调用函数时,函数作用域被创建,函数执行完毕,函数作用域被销毁
    (2)每调用一次函数就会创建一个新的函数作用域,他们之间时相互独立的
    (3)在函数作用域中可以访问到全局作用域的变量,在函数外无法访问到函数作用域内的变量
    (4)在函数作用域中访问变量,函数时,会先在自身作用域中寻找,若没有找到,则会到函数的上一级作用域中寻找,一直到全局作用域

作用域的深层次理解

  • 执行期的上下文
    • 当函数代码执行的前期,会创建一个执行期上下文的内部对象ao(作用域)
    • 这个内部的对象是预编译的时候创建出来的 因为当函数被调用的时候 会先进行预编译
    • 在全局代码执行的前期会创建一个执行期的上下文的对象GO

函数作用域的预编译

  1. 创建AO对象 AO{}
  2. 找形参和变量声明 将变量和形参名当作AO对象的属性名,值为undefined
  3. 实参形参相统一
  4. 在函数体里面找函数声明 值赋予函数体

全局作用域的预编译

  1. 创建GO对象
  2. 找变量声明 将变量名作为GO对象的属性名 值为undefined
  3. 找函数声明 值赋予函数体

预编译题目

    <script>
        function fn(a,c) {
            console.log(a);//function
            var a = 123
            console.log(a);//123
            console.log(c);//function
            function a() {}
            if (false) {
                var d = 678
            }
            console.log(d);//undefined
            console.log(b);//undefined
            var b = function () {}
            console.log(b);//function
            function c() {}
            console.log(c);//function
        }
        fn(1,2)
        
        //解题思路
        // AO{
        //     a:undefined 1 function
        //     c:undefined 2 function
        //     d:undefined 
        //     b:undefined
        // }
    </script>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值