首页 > 其他分享 >JS打包简史

JS打包简史

时间:2022-10-14 19:22:42浏览次数:86  
标签:模块 JavaScript js 简史 https JS 打包

目录

了解打包的历史可以更好的知道事物发展的趋势

暗黑阶段

2009以前

在2009年之前的前端历史里,基本是不存在打包这个说法的。最开始的网页基本是纯静态的HTML或者服务端输出,js能做的事情也比较有限。

直到2004年,也就是Google 推出 Gmail 的时候,AJAX开始被广泛使用,也就是用JavaScript执行异步网络请求。JS相关的前端技术开始大发展,比如著名的jQuery。

黎明阶段

2009年以后

2009年Nodejs发布,使得JS在服务器端也能使用,同时也促进了整体JS相关技术的发展。如npm的提出也是在2009年 commonjs 作为JS模块系统被使用到Nodejs中

// 定义模块 add.js
function add (a, b) {
    return a + b;
}
module.exports = {
    add
}

// 使用模块 app.js
const { add } = require('./add');
console.log(add(1, 2));

但是 CommonJS 在浏览器内并不适用。因为 require() 的返回是同步的,意味着有多个依赖的话会阻塞 JS脚本的执行。

解决方案1: 使用AMD,在 CommonJS 的基础上定义了 Asynchronous Module Definition (AMD) 规范(2011 年),使用了异步回调的语法来并行下载多个依赖项。

解决方案2: 使用Browserify,它会从入口 js 文件开始,把所有的 require() 调用的文件打包合并到一个文件,这样就解决了异步加载的问题。

从Browserify开始有JS打包的概念,Webpack成为集大成者,后来出现基于编译型语言的Swc、Esbuild,显著提升打包速度。近两年又新出现基于浏览器原生 ES 模块的Snowpack、Vite。

时间线

img

Browserify

通过将依赖打包,可以使浏览器运行NodeJS编写的前端js代码,也就是require(‘modules’)

browserify main.js -o bundle.js

通过script标签在HTML中使用

<script src="./bundle.js"/>

存在的问题

  1. 不支持把代码打包成多个文件

  2. 对其他非 js 文件的加载不够完善

  3. 只支持 commonJS 模块规范,不支持 AMD 和 ES6 模块规范

Webpack

一个用于现代 JavaScript 应用程序的静态模块打包工具

Bundle Everything: 一站式解决方案

Code Splitting: 解决打包后的体积问题、优化了前端性能

Hot Module Replacement (HMR):极大的提升了开发体验和开发效率

Plugins: 丰富的生态

Rollup

基于ES modules的新一代JavaScript 模块打包器

ES modules: 直接使用es modules,不用babel的转化

Tree-shaking: 删除冗余代码,进一步缩小代码体积

适用于构建基于ES6模块开发的、相对简单的bundle包

Parcel

随着webpack的配置越来越复杂,开箱即用/零配置的Parcel应运而生

越是使用JS,就越会发现JS的能力 是有极限 的,除非超越JS

Swc

用 Rust 实现的一套 TypeScript/JavaScript compiler,性能较 babel/ts 快 20 倍

Esbuild

An extremely fast JavaScript bundler

使用Go实现的JS打包工具

Why is esbuild fast ?

It's written in Go[1] and compiles to native code.

Parallelism is used heavily.

Everything in esbuild is written from scratch.

Memory is used efficiently.

Esbuild-loader

在webpack中使用Esbuild处理JS/TS文件

Snowpack

Snowpack is a lightning-fast frontend build tool, designed to leverage JavaScript's native module system

超越打包的极限,不再打包业务代码,而是直接使用浏览器原生的 JavaScript Module[2] 能力,dev-server可以在50ms内启动

基本原理:整体生态不够完善,基于webpack的复杂一点的项目基本跑不起来

Vite

Vite (法语意为 "快速的",发音 /vit/) 是一种新型前端构建工具,能够显著提升前端开发体验

  • 开发服务器基于浏览器原生 ES 模块,毫秒级别快速启动,快速热更新

  • 使用 esbuild 来进行依赖预构建,使用Rollup来进行生产环境打包

  • Vue第一优先级支持,但是Vite 2.0 版本完全不依赖于任何框架,比如React也能用

Monorepo 支持

参考链接:

swc[3]

Rollup[4]

webpack[5]

Snowpack[6]

Home | Vite 官方中文文档[7]

Parcel 中文文档 | Parcel 中文网[8]

esbuild - An extremely fast JavaScript bundler[9]

引用链接

[1] Go: https://golang.org/
[2] JavaScript Module: https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Guide/Modules
[3] swc: https://swc.rs/
[4] Rollup: https://rollupjs.org/guide/en/
[5] webpack: https://webpack.js.org/
[6] Snowpack: https://www.snowpack.dev/
[7] Home | Vite 官方中文文档: https://cn.vitejs.dev/
[8] Parcel 中文文档 | Parcel 中文网: https://www.parceljs.cn/
[9] esbuild - An extremely fast JavaScript bundler: https://esbuild.github.io/

原文地址

https://baijiahao.baidu.com/s?id=1717025204678506713

标签:模块,JavaScript,js,简史,https,JS,打包
From: https://www.cnblogs.com/hhddd-1024/p/16792734.html

相关文章

  • js querySelector选#ID报错
    code:document.querySelector("#02b51fd4-c350-65d3-c59a-cfdc5a538066")err:UncaughtDOMException:Document.querySelector:'#02b51fd4-c350-65d3-c59a-cfdc5a5380......
  • js
    应用场景嵌入到网页中运行,实现一些动态效果,表单验证,操作cookie,操作DOM等使用方法外部方式在body内使用scipt标签index.html<!DOCTYPEhtml><htmllang="en"><head>......
  • 使用nvm 管理工具切换nodeJs的版本
    由于项目的不同,有的前端项目使用不同的nodeJs版本运行,所以可下载一下nvm管理工具来切换nodeJs的版本去运行项目借鉴博客:https://www.jb51.net/article/202124.htm nvm......
  • HU打包BAPI:内部给号 更新交货单
    其他相关资料可点击:​​HU相关配置​​​​HU打包 内外部给号 前台操作​​代码输入参数:内向交货单号*"--------------------------------------------------------------......
  • 转载:ElementUI源码系列一 - 从零搭建项目架构,项目准备、项目打包、项目测试流程
    创建入口文件首先,在你的电脑里寻找一个风水宝地,创建一个文件夹,通过 npminit-y,初始化 package.json文件;创建 src文件夹,在它下面创建 src/index.js入口文件,它是我们项......
  • Mac M1 docker打包x86平台平台镜像(解决m1打包的镜像在x86中不可用问题)
    buildxdocker版本19.03之后添加buildx,可构建多架构镜像构建build时添加参数:buildx--platform=linux/amd64dockerbuildxbuild--platform=linux/amd64-t[im......
  • 项目打包
    vue.2.0(webpack)打包配置vue.config.jsmodule.exports={publicPath:'./',}rout文件onstrouter=newVueRouter({ mode:'history',把history改......
  • 通过js实现单击或双击直接修改内容
    span标签:<spanclass="text-info"id="pay_type"οndblclick='edit(this,this.id)'>{if!empty($data['pay_type'])}{$data['pay_type']}{else/}双击文字修改{/if}</sp......
  • uni-app 24egg.js 基础课
    24.1创建egg.js项目24.2写第一个api接口24.3-24.5router路由相关24.6数据库迁移(一)24.7数据库迁移(二)24.8sequelize模型-新增24.9sequelize模型-批量新增和修改器24.1......
  • js文本框失去焦点和获取焦点时不同显示
    获取焦点时隐藏文本框内容,失去焦点时显示文本框内容 获得焦点事件:onfocus失去焦点事件:onblur css样式代码:<style>.box{width:300px;......