Javascript 项目如何工作:深入探讨转译器、捆绑器等
来源:dev.to
时间:2024-08-22 16:54:46 483浏览 收藏
在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是文章学习者,那么本文《Javascript 项目如何工作:深入探讨转译器、捆绑器等》就很适合你!本篇内容主要包括##content_title##,希望对大家的知识积累有所帮助,助力实战开发!
介绍
了解 JavaScript 项目如何真正发挥作用一直让我很感兴趣。虽然我们中的许多人都精通编写代码,但并不是每个人都能清楚地解释编写代码后幕后发生的情况。
在本文中,我们将探讨一切在幕后是如何运作的。
超过 98.7% 的网站使用 JavaScript。
来源:Radixweb
概述
当您构建应用程序时,需要使用许多工具来提供美观且高性能的应用程序:
- ⚙️
转译器:它的工作是确保您的代码可以在不同的环境中运行! 将其视为确保您奶奶的旧电脑可以顺利处理您的应用程序!
- ??♂️
捆绑器:就像超级英雄一样,它优化您的代码,使其更高效地加载和执行。它将您的所有资源捆绑到一个文件中,从而减少您的应用程序必须发出的请求数量。
- ?
任务运行器:这些是您开发过程中的黑暗骑士。 它们自动执行日常任务,例如文件缩小(压缩代码)、编译(将 SCSS 转换为 CSS)和图像优化。它们使我们不必手动处理这些繁琐的任务。
深入探讨:它们是如何工作的
当您构建项目时,
任务运行者会编排流程,协调转译器和捆绑器以确保简化且高效的构建。
Babel 等转译器获取现代 Javascript (ES6+) 或 Typescript 中的源代码,并将其转换为与旧版浏览器 (ES5) 兼容的 Javascript。像 Webpack 这样的打包器会获取所有文件(Javascript、CSS、图像等...)并将它们编译成更小的文件甚至单个文件。
在此过程中,Webpack 还通过最小化和压缩代码来优化代码,从而减少加载时间并提高性能。
是和否,如果没有太多复杂性,您的项目就可以工作。
如果您开始增加复杂性,缺乏这些工具可能会带来重大挑战:
代码兼容性:如果没有转译器,您的 JavaScript 代码可能无法在旧版浏览器上正确运行,从而限制了您的受众。
性能:如果没有捆绑器,您的应用程序可能会由于未优化的代码交付而导致加载时间变慢。
效率:如果没有任务运行程序,您将需要手动处理重复性任务,从而导致构建过程效率低下并可能出现错误。
示例工作流程
1 - 编写现代 JavaScript 代码:
您在源文件中编写 ES6+ 或 TypeScript。
2 - 运行构建命令:
您执行触发编译器的构建命令(npm run build)。
--开始构建过程--
3 - 转译代码:
转译器(例如 Babel)将您的 ES6+ 代码转换为 ES5。
4 - 捆绑文件:
捆绑器(例如 Webpack)然后获取转译的文件并将它们组合成一个或几个优化的文件。
-- 构建过程结束 --
5 - 部署:
最终的捆绑文件已经准备好部署到服务器了。
任务运行器不是构建过程本身的一部分,而是编排它。它们通过与 Babel 和 Webpack 等工具集成来自动化和管理转译和捆绑等任务。从本质上讲,任务运行程序简化和协调整个构建过程,确保任务按正确的顺序执行。
感谢您的阅读?
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
434 收藏
-
500 收藏
-
428 收藏
-
398 收藏
-
161 收藏
-
182 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习