当前位置:首页 > 文章列表 > 文章 > 前端 > Javascript 项目如何工作:深入探讨转译器、捆绑器等

Javascript 项目如何工作:深入探讨转译器、捆绑器等

来源:dev.to 2024-08-22 16:54:46 0浏览 收藏

在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 等工具集成来自动化和管理转译和捆绑等任务。从本质上讲,任务运行程序简化和协调整个构建过程,确保任务按正确的顺序执行。


感谢您的阅读?

Javascript 项目如何工作:深入探讨转译器、捆绑器等

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
在 PHP 中创建和使用命名空间函数在 PHP 中创建和使用命名空间函数
上一篇
在 PHP 中创建和使用命名空间函数
2024 年《财富》中国科技 50 强榜单首发,华为、比亚迪、宁德时代等上榜
下一篇
2024 年《财富》中国科技 50 强榜单首发,华为、比亚迪、宁德时代等上榜
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 毕业宝AIGC检测:AI生成内容检测工具,助力学术诚信
    毕业宝AIGC检测
    毕业宝AIGC检测是“毕业宝”平台的AI生成内容检测工具,专为学术场景设计,帮助用户初步判断文本的原创性和AI参与度。通过与知网、维普数据库联动,提供全面检测结果,适用于学生、研究者、教育工作者及内容创作者。
    3次使用
  • AI Make Song:零门槛AI音乐创作平台,助你轻松制作个性化音乐
    AI Make Song
    AI Make Song是一款革命性的AI音乐生成平台,提供文本和歌词转音乐的双模式输入,支持多语言及商业友好版权体系。无论你是音乐爱好者、内容创作者还是广告从业者,都能在这里实现“用文字创造音乐”的梦想。平台已生成超百万首原创音乐,覆盖全球20个国家,用户满意度高达95%。
    26次使用
  • SongGenerator.io:零门槛AI音乐生成器,快速创作高质量音乐
    SongGenerator
    探索SongGenerator.io,零门槛、全免费的AI音乐生成器。无需注册,通过简单文本输入即可生成多风格音乐,适用于内容创作者、音乐爱好者和教育工作者。日均生成量超10万次,全球50国家用户信赖。
    21次使用
  •  BeArt AI换脸:免费在线工具,轻松实现照片、视频、GIF换脸
    BeArt AI换脸
    探索BeArt AI换脸工具,免费在线使用,无需下载软件,即可对照片、视频和GIF进行高质量换脸。体验快速、流畅、无水印的换脸效果,适用于娱乐创作、影视制作、广告营销等多种场景。
    24次使用
  • SEO标题协启动:AI驱动的智能对话与内容生成平台 - 提升创作效率
    协启动
    SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
    23次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码