JavaScript百炼成仙 1,快手前端面试题

“叶小凡,你这是再逗我吗,这么简单的代码谁看不懂?”对面弟子感到有些不耐烦。

“师兄,你先别急,没错,这无非就是一个简单的定义语句,可是,你知道它内部的原理吗?JavaScript代码再运行之前,会经过一个编译的过程,而编译有三个步骤。”叶小凡不紧不慢地说到。

“哦,小娃娃,你可好好说说,是哪三个步骤?”尹曾琪也来了兴趣,因为身为掌尊地他,也是头一次听说这个讲法。

“首先第一个步骤是分词,JavaScript代码其实就是由一句句话组成的,分词的目的就是把这些代码分解为一个个有意义的代码块。比如刚才的例子,如果经过分词的步骤,得到的结果就是var、a、=、2、;”

“第二个步骤是解析,由JavaScript编译器去将刚才分词得到的一个个代码块进行解析,生成一棵抽象的语法树(AST)。

这么讲的话有点难以理解,简单来说,JavaScript代码是没有办法直接运行的,要运行JavaScript代码,就需要由JavaScript编译器对其进行编译,只有编译之后的代码才可以被识别,然后再由JavaScript引擎去执行代码逻辑。

但是,由于JavaScript这门编程语言的特殊性,编译的过程一般就在代码执行前的几个微秒之内,甚至更短。所以,直观地看,编译和运行是同时发生的。

或者说,我们根本感受不到编译的存在。就比如刚才的例子。var a = 10; 编译的过程实在是太短太短了,我们根本就感觉不到编译的存在。

但其实JavaScript引擎早在我们运行这段代码的时候,就已经完成了编译,然后立刻就做好了要执行代码的准备。”

“那你说的抽象语法树是怎样的?”

“抽象语法树定义了代码本身,通过操作这颗树,可以精准的定位到赋值语句、声明语句和运算语句。”叶小凡不紧不慢地说到。

“再来说说刚才的代码,很明显,这是一个赋值语句,当然,也是一个定义的语句。我们通过JavaScript的解析器来把它解析为一棵抽象树。”

“让我们一个一个来看,首先是最顶层的大节点,也就是这棵树的顶端,上面清清楚楚地写着Program body,这代表我们写的代码是一个程序。然后再看这个程序里面的第一个,也是唯一的一个子节点,上面清清楚楚地写着VariableDeclaration,意思就是变量声明。哦,这就很明白了,var a = 10; 这句话是一个程序,程序的目的是做了一个变量的声明。现在,让我们展开这个子节点看看,里面还有什么玄奥?”

“在VariableDeclaration(变量声明)节点中,包含了两个子节点,一个是declarations[1],另一个是kind。declarations[1]是声明数组,中括号里面写了一个1,表示我们这个语句里面一共只声明了一个变量。Kind代表种类,我们是用var关键字来声明一个变量的,我想,到这一步,应该没有什么问题。”

“继续展开declarations[1],发现一个VariableDeclarator节点,这个也表示变量声明,正因为上一个父节点是declarations[1],[1]表示里面只有一个声明,因此我们看到展开后里面也只有一个子节点。”

“好,终于看到变量声明的具体信息了,可以看到里面分为id和init两个子节点,id代表变量名,identifier是标识符,在这里就代表我们的变量名,也就是a。Init表示变量的初始化操作,从我们的语句上也能看出,是将文字的10赋给a变量。”

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

最后

总的来说,面试官要是考察思路就会从你实际做过的项目入手,考察你实际编码能力,就会让你在电脑敲代码,看你用什么编辑器、插件、编码习惯等。所以我们在回答面试官问题时,有一个清晰的逻辑思路,清楚知道自己在和面试官说项目说技术时的话就好了

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算**

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值