登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
博客
发1篇日志+1圆
记录
发1条记录+2圆币
发帖说明
VIP申请
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
VIP申请
VIP网盘
网盘
联系我们
道具
勋章
任务
设置
我的收藏
退出
腾讯QQ
微信登录
返回列表
首页
›
业界区
›
业界
›
都2024年了你还傻傻分不清楚“编译时”和“运行时”吗? ...
都2024年了你还傻傻分不清楚“编译时”和“运行时”吗?
[ 复制链接 ]
班嘉淑
2025-6-6 15:39:01
前言
在写vue3编译原理揭秘电子书的时候,发现有不少粉丝还傻傻分不清楚什么是编译时?什么是运行时?这篇文章我们来让你彻底搞清楚编译时和运行时的区别。
关注公众号:【前端欧阳】,给自己一个进阶vue的机会
编译时
我将编译这个词语理解为翻译,这句话是什么意思呢?
比如你要和一个老外沟通,你的英文超级烂。所以你说的是中文,老外却只理解英文。那你们两个人怎么沟通呢?所以你需要一个翻译器来将你说的中文转换为英文,这样老外就能理解你说的话了,
这个翻译过程就是我们常说的编译时
。
看完上一个例子如果你还没理解的话,我们再来看一个vue的例子。我们平时写vue代码时一般都是写在文件后缀名为.vue文件中,也就是官方说的单文件组件 (SFC)。
但是浏览器认识后缀为.vue的单文件组件 (SFC)吗?
很明显浏览器是不认识的,所以这个时候需要将后缀为.vue的单文件组件 (SFC)编译(翻译)为浏览器认识的js文件,
这一过程就是我们常说的编译时
。
在前端中,一般来说编译时就是代码跑在node.js的阶段。
大家都知道前端主要分为两个环境:生产环境和开发环境。
对于生产环境来说,编译时就是在执行类似yarn build之类的命令,将源代码打包成浏览器可直接执行的代码这一过程。打包生成的代码文件是存在磁盘中,这一过程是在node.js中完成的。
对于开发环境来说,编译时就是在执行类型yarn dev这种启动命令,同样将源代码编译成浏览器可直接执行的代码这一过程。和生产环境不同的是生成的代码文件是存在内存中,并不会写到磁盘中,同样这一过程是在node.js中完成的。
运行时
还是以vue举例,大家都知道浏览器的渲染过程是将一个html文件渲染到页面上的。在SPA单页面中浏览器接收到的index.html一般是下面这样的,如下图:
从上图中可以看到接收到的html文件中只有一个,那么浏览器又是怎么从这个空div渲染成丰富多彩的页面呢?
熟悉vue源码的同学应该比较清楚,首先是生成一个app对象,然后调用app对象的mount方法将经过编译时处理后拿到的vue组件对象挂载到上面。
这一过程就是所谓的运行时。
对于前端来说,运行时就是代码执行在浏览器的阶段。
在浏览器中编译
看到这里有的小伙伴会有疑惑了,vue好像还提供了一种全局构建的版本。在这个版本中我们可以直接在html文件中使用vue,无需使用webpack或者vite这种打包工具打包。比如下面这样:
从上图中可以看到,这种用法中除了将*.vue文件名替换为*.html文件名之外,其他的写法基本是一模一样的。在这种用法中由于没有使用到构建工具webpack或者vite,当然就没有在node.js中执行的编译时,那么这种用法中浏览器又是如何识别单文件组件 (SFC)中的、<script> 和 等模块呢?
答案是在这种全局构建版本的vue中会内置一个编译器。在浏览器中运行时如果发现了、<script> 和 等模块的代码就会使用内置的编译器将这些模块编译成浏览器可执行的代码。
所以我们前面才会讲:一般来说编译时就是代码跑在node.js的阶段。不一般的情况就是现在这种情况,vue直接内置了一个编译器,在浏览器中进行编译。但是话说回来,这种在浏览器中编译的模式,性能肯定不如使用构建工具webpack或者vite提前将资源进行打包。
总结
一般情况下编译时就是代码跑在node.js的阶段,比如执行yarn dev或者yarn build时代码在node.js中执行的阶段。后面我们又讲了运行时实际就是代码在浏览器中执行的阶段。
最后我们又讲了还有一种特殊的情况,像全局构建版本的vue中会内置一个编译器。让我们可以脱离webpack或者vite使用vue,这种情况就是在浏览器中进行编译的模式,当然这种模式的性能肯定不如使用构建工具webpack或者vite提前将资源进行打包。
关注公众号:【前端欧阳】,给自己一个进阶vue的机会
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
2024年
傻傻分
不清楚
编译
运行时
相关帖子
JIT 编译优化原理深度解析
ArkUI-X与Android联动编译开发指南
c++ 预处理 编译 链接 文件组织形式
AWTK项目编译问题整理(1)
C#脚本化(Roslyn):如何在运行时引入nuget包
AirSim在UE4中运行时显示第一人称捕获图像窗口
AI Agent 运行时相比传统应用有什么不同:百家企业 AI 实践观察(二)
pnpm 10.14 支持JavaScript运行时的安装了
预编译出错shell
Rust异步运行时最小实现 - extreme 分享
vip免费申请,1年只需15美金$
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
业界
JIT 编译优化原理深度解析
0
134
姜删懔
2025-06-15
业界
ArkUI-X与Android联动编译开发指南
0
1019
笃扇
2025-06-16
业界
c++ 预处理 编译 链接 文件组织形式
0
65
滕佩杉
2025-06-20
业界
AWTK项目编译问题整理(1)
0
641
红弘丽
2025-07-07
业界
C#脚本化(Roslyn):如何在运行时引入nuget包
0
450
杼氖
2025-07-10
安全
AirSim在UE4中运行时显示第一人称捕获图像窗口
0
320
铵滔
2025-07-27
安全
AI Agent 运行时相比传统应用有什么不同:百家企业 AI 实践观察(二)
0
836
宿遘稠
2025-07-29
业界
pnpm 10.14 支持JavaScript运行时的安装了
0
1054
椎蕊
2025-08-03
程序
预编译出错shell
0
8
新程序
2025-09-07
安全
Rust异步运行时最小实现 - extreme 分享
0
663
史华乐
2025-09-09
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
浏览过的版块
安全
科技
代码
签约作者
程序园优秀签约作者
发帖
班嘉淑
2025-6-6 15:39:01
关注
0
粉丝关注
18
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
敖可
9984
黎瑞芝
9990
杭环
9988
4
凶契帽
9988
5
氛疵
9988
6
猷咎
9986
7
里豳朝
9986
8
肿圬后
9986
9
蝓俟佐
9984
10
虽裘侪
9984
查看更多