看完这篇文章后,别再说你不懂JS执行机制

案例一:

js 复制代码
showName()
console.log(a);

var a = 1
function showName() {
    console.log("name");
}

/*
输出结果:
 name
 undefined
*/

很多小伙伴要说了,这不是很简单吗?不就是个变量提升

对的,那么面试官 要问了,什么是变量提升

V8:原来你叫变量提升

问题来了,V8如何处理这段代码?

先来说说JS的执行流程:读取代码 -> 编译 -> 执行
编译阶段:

V8会先找到所有变量声明,此时,变量值为undefined,函数只是声明,但不执行

执行阶段:

1、变量赋值(考虑作用域)
2、按照代码书写顺序进行执行

此时,按照顺序,先执行函数内的代码,此时a=undefined,执行console.log(a),再执行赋值操作a = 1。

于是乎,就出现了如下输出结果:

js 复制代码
/*
输出结果:
 name
 undefined
*/

案例二:

js 复制代码
var a =2
function add(b,c){
    return b+c
}

function addAll(b,c){
    var d = 10
    var result = add(b,c)
    return a + result + d
}

addAll(3,6)

有小伙伴又要说了,这不是也很简单吗?根据作用域的规则,到全局变量里找a的值。

对的,那么面试官要问了,为什么要这样找值?

再次代入V8视角:用栈结构(先进后出)演示如何找a的值

有小伙伴可能会问,你的a怎么就赋值了,你在胡说八道吗?我要辩解一下,执行完当前作用域(全局)的变量声明后,当然要执行了,所以a=undefined -> a=2,我这里简写了

案例三

请问,a的输出结果是什么,再用V8视角看待,那么答案就显而易见了

js 复制代码
var a = 1
function fn(a) {
    var a = 2
    function a() { }
    var b = a
    console.log(a) // 2
}
fn(3)
相关推荐
jiayong235 分钟前
第 17 课:任务选择与批量操作
开发语言·前端·javascript·vue.js·学习
源码老李12 分钟前
Day 07 · 游戏也要管理状态:场景切换·资源加载·对象池实战
前端·javascript·游戏
donecoding18 分钟前
遗嘱、水管与抢救室:TS 切入 Go 的流程控制、接口与并发
javascript·typescript·go
天才熊猫君20 分钟前
📄 第三篇:Vue 3 命令式弹窗 Provide 污染与关闭动画修复
前端·javascript·vue.js
天才熊猫君26 分钟前
📄 第一篇:Vue 3 命令式弹窗使用指南
前端·javascript·vue.js
天才熊猫君27 分钟前
📄 第二篇:Vue 3 命令式弹窗 provide/inject 机制解析
前端·javascript·vue.js
iReachers29 分钟前
HTML打包EXE工具数据加密功能详解 - 加密保护HTML/JS/CSS资源
javascript·css·html·html加密·html转exe·html一键打包exe·exe打包
kyriewen1134 分钟前
代码写成一锅粥?这5种设计模式让你的项目“起死回生”
前端·javascript·设计模式·typescript·ecmascript·html5
skywalk816336 分钟前
g4f JavaScript调用报错问题解决
开发语言·javascript·ecmascript