每天一个前端小技巧(二):预编译过程(面试常见判断输出值)

预编译
作用域的创建阶段,就是预编译阶段,在预编译时,主要做了以下事情
1.创建AO对象(js变量对象,提供给js引擎自己去访问的对象)
2.找到形参和变量的声明,作为AO对象的属性名,值为undefined
3.实参和形参相统一
4.找函数声明,会覆盖变量声明
具体案例如下:
分别判断以下值的输出为多少
function fn(a, c) {
            console.log(a)
            var a = 123
            console.log(a)
            console.log(c)
            function a() {} // 是函数声明
            if (false) {
                var d = 678
            }
            console.log(d)
            console.log(b)
            var b = function() {}  // 注意这个不是函数声明
            console.log(b)
            function c() {} // 是函数声明
            console.log(c)
        }

        fn(1, 2)
分析过程
AO: {
	a: undefined 1 function a(){}
	c: undefined 2 function c(){}
	d: undefined
	b: undefined
}
通过以上方式我们可以知道具体的输出值了
function fn(a, c) {
            console.log(a) // 本来a传进来的值为1,但是函数声明会覆盖变量的声明,所以这里的a值为function a(){}
            var a = 123
            console.log(a) // a为123 因为被重新赋值为123
            console.log(c) // 本来c传进来的值为2,但是函数声明会覆盖变量的声明,所以这里的c值为function c(){}
            function a() {}
            if (false) { // 不会进入到这个判断
                var d = 678
            }
            console.log(d) // d为undefined
            console.log(b) // b为undefined
            var b = function() {}
            console.log(b) // function(){}
            function c() {}
            console.log(c) // function c(){}
        }

        fn(1, 2)
以上就是预编译的案例分析啦,小伙伴们可以多找题试试
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值