首页 > 其他分享 >[Tools] SWC Intro

[Tools] SWC Intro

时间:2025-01-20 10:21:49浏览次数:1  
标签:false SWC JavaScript js Intro Tools swc Rust

SWC

SWC 英文全称为 Speedy Web Compiler,翻译成中文为“快速网页编译器”。

官网地址:https://swc.rs/

16894863108763

来看一下官方的介绍:

SWC is an extensible Rust-based platform for the next generation of fast developer tools. It's used by tools like Next.js, Parcel, and Deno, as well as companies like Vercel, ByteDance, Tencent, Shopify, and more.

SWC can be used for both compilation and bundling. For compilation, it takes JavaScript / TypeScript files using modern JavaScript features and outputs valid code that is supported by all major browsers.

中文的意思就是:

SWC 是一个基于 Rust 的可扩展平台,用于下一代高速开发工具。它被 Next.js、Parcel、Deno 等工具,以及 Vercel、字节跳动、腾讯、Shopify 等公司广泛使用。

SWC 既可以用于编译,也可以用于打包。在编译方面,它接受使用现代 JavaScript 功能的 JavaScript / TypeScript 文件,并输出由所有主流浏览器支持的有效代码。

那么 SWC 的特点是什么呢?就一个特点:快。

看一看官方对于 SWC 速度的描述:

SWC is 20x faster than Babel on a single thread and 70x faster on four cores.

也就是说,当只使用一个 CPU 核心(即单线程环境)时,SWCBabel20 倍。而当使用四个 CPU 核心(即四核环境,能够进行并行处理)时,SWCBabel70 倍。

没错,SWC 对标的就是 Babel,力图成为 Babel 的替代品。而 SWC 之所以可以那么快,主要是由于以下几个因素:

  1. 编程语言:SWC 是用 Rust 语言编写的。Rust 是一种系统编程语言,它旨在提供内存安全性,无数据竞争,并且有着高效的性能。Rust 的执行速度通常比 JavaScript 快。

  2. 并行处理:Rust 具有优秀的并行处理和并发能力。当在多核 CPU 上运行时,SWC 能够有效地利用这些核心并行执行任务,从而大大提高了处理速度。

  3. 优化的设计:SWC 设计上对性能进行了优化。例如,它使用一次性遍历(single-pass traversal)来转换代码,这种方法比 Babel 使用的多次遍历更高效。

  4. 跳过不必要的工作:与 Babel 不同,SWC 可以跳过一些不必要的工作,例如不需要生成和处理 source maps,除非明确需要。

早期各种前端工具都是基于 Node.js 来写的,Node.js 本身只是一个 JS 的运行时,JS 本身又是一门单线程解释语言,所以 JS 的运行速度不会比像 Rust、Go 这种语言快。

这几年开始就有一种趋势,用其他的编程语言来编写前端工具,甚至还专门出现了一个词语 rustification(锈化),就是指使用 rust 语言来翻新已有的前端工具,从而提升工具的性能。

  • SWC:使用 Rust 编写的超快速的 JavaScript/TypeScript 编译器。它的目标是替代Babel
  • TurbopackVercel 声称这是 Webpack 的继任者,用 Rust 编写,在大型应用中,展示出了 10 倍于 Vite700 倍于 Webpack 的速度。
  • esbuild: esbuild 是由 Go 编写的构建打包工具,对标的是 webpack、rollupparcel 等工具,在静态语言的加持下,esbuild 的构建速度可以是传统 js 构建工具的 10-100 倍,就好像跑车和自行车的区别。
  • Rome: 是一个使用 Rust 编写的全栈工具链,它打算整合各种前端开发工具的功能,从而提供一个统一的、一体化的开发体验。Rome 的目标是替代或集成诸如 Babel、ESLint、Webpack、Prettier、Jest 等多个分散的工具。
  • Deno: 是一个使用 RustTypeScript 编写的 JavaScript/TypeScript 运行时,它的目标是成为一个更安全、更高效的 Node.js 替代品。

虽然编写这些工具的语言发生了变化,但是我们使用这些工具的方法是没变的:

  • API
  • CLI
  • 配置

API

新建一个项目 swc-demo,使用 pnpm init 进行初始化,安装依赖

pnpm add @swc/core -D

接下来在 src/index.js 中书写测试代码:

const greet = (name) => `Hello, ${name}!`;
console.log(greet("World"));

之后在项目根目录下创建 compile.js,在该文件中利用 swc 提供的 api 对文件进行编译

const swc = require("@swc/core");
const fs = require("fs");
const path = require("path");

// 拼接路径
const codePath = path.resolve("src", "index.js");
const sourceCode = fs.readFileSync(codePath, "utf8");
const outDir = path.resolve(__dirname, "dist");

swc
  .transform(sourceCode, {
    jsc: {
      target: "es5", // 设置目标JavaScript版本
      parser: {
        syntax: "ecmascript", // 设置源代码的语法
      },
    },
  })
  .then((res) => {
    // console.log(res.code)
    if (!fs.existsSync(outDir)) {
      fs.mkdirSync(outDir);
    }

    const outputFilePath = path.join(outDir, "index.js");
    fs.writeFileSync(outputFilePath, res.code);
  })
  .catch((err) => {
    console.error(err);
  });

CLI

首先需要安装相应的 CLI 工具

pnpm add @swc/cli -D

之后就可以在 https://swc.rs/docs/usage/cli 看到 swc 所支持的所有的 CLI 命令

然后在 package.json 中进行 CLI 的配置即可,例如:

"scripts": {
    // ...
    "swc": "swc src -d lib"
 },

配置

我们在使用 transform 方法的时候,第二个参数就是一个配置对象。

你可以在 https://swc.rs/docs/configuration/compilation 看到所有所支持的配置选项。

如果你没有配置文件.swcrc,那么会有一个默认的配置设置:

{
  //  这个配置项用于设置 JavaScript的 编译选项
  "jsc": {
    // 这个配置项用于设置解析器的选项
    "parser": {
      // 设置源代码的语法,可以是 ecmascript、jsx、typescript 或 tsx
      "syntax": "ecmascript",
      // 是否启用JSX语法
      "jsx": false,
      // 是否启用动态 import() 语句
      "dynamicImport": false,
      // 是否启用私有方法和访问器
      "privateMethod": false,
      // 是否启用函数绑定语法(::操作符)
      "functionBind": false,
      // 是否启用 export v from 'mod' 语法
      "exportDefaultFrom": false,
      // 是否启用 export * as ns from 'mod' 语法
      "exportNamespaceFrom": false,
      // 是否启用装饰器语法
      "decorators": false,
      // 是否在导出之前应用装饰器
      "decoratorsBeforeExport": false,
      // 是否启用顶级 await 语法
      "topLevelAwait": false,
      // 是否启用 import.meta 语法
      "importMeta": false,
      // 是否保留所有注释
      "preserveAllComments": false
    },
    // 设置转换插件,通常不需要手动设置
    "transform": null,
    // 设置目标 JavaScript 版本
    // 例如 es3、es5、es2015、es2016、es2017、es2018、es2019、es2020
    "target": "es5",
    // 是否启用宽松模式,这会使编译后的代码更简短,但可能不完全符合规范
    "loose": false,
    // 是否引用外部的 helper 函数,而不是内联它们
    "externalHelpers": false,
    // 是否保留类名,这需要版本 v1.2.50 或更高
    // 且 target 需要设置为 es2016 或更高
    "keepClassNames": false
  },
  // 这个配置项用于指示输入的源代码是否是模块代码。
  // 如果是,那么 import 和 export 语句将被正常处理
  // 否则,它们将被视为语法错误
  "isModule": false
}

标签:false,SWC,JavaScript,js,Intro,Tools,swc,Rust
From: https://www.cnblogs.com/Answer1215/p/18680852

相关文章

  • [Terser] Intro
    TerserTerser是一个流行的JavaScript解析器和压缩器,它可以帮助你优化JavaScript代码以减少其大小,从而提高web页面的加载速度。Terser是Uglify-es的替代品,后者已经停止维护,Terser支持ES6和更高版本的JavaScript。Terser官网:https://terser.org/以下是Terser的......
  • [Babel] Intro Babel - 05. API
    APIs关于babel里面的APIs主要位于@babel/core这个依赖里面,你可以在官网左下角的ToolingPackages分类下找到这个依赖包。这里顺便介绍一下每一种依赖包的作用:@babel/parser:是Babel的解析器,用于将源代码转换为AST。@babel/core:Babel的核心包,它提供了Babel的......
  • [Babel] Intro Babel - 02 Configure file
    配置文件配置文件格式配置文件选项配置文件的格式在babel中,配置文件本身又可以分为两种:项目范围的配置文件文件相关配置文件项目范围配置文件顾名思义,就是该配置文件针对整个项目生效的一个配置,这种类型的配置文件一般放在项目根目录下面,babel对项目范围级别的配置......
  • [Babel] Intro Babel - 03. CLI
    CLI关于babel所提供的CLI,你可以在https://babeljs.io/docs/babel-cli看到所有所支持的CLI命令。要使用CLI命令,首先第一步是安装:pnpmadd--save-dev@babel/core@babel/cli注意在安装@babel/cli这个包的时候,需要同时安装@babel/core这个包,这个包是提供babel......
  • Babel Intro Babel - 01 Introduction
    Babel介绍Babel是一个编译器,主要用于将最新的JavaScript代码转化为向后兼容的代码,以便在老版本的浏览器或环境中运行。例如,你可能在开发时使用了ES6、ES7或者更高级的JavaScript特性,但是有些浏览器可能并不支持这些新特性,这时就可以用Babel来将代码转化为ES5或者更早......
  • CheeseTools:红队内网横向
    免责声明仅限用于技术研究和获得正式授权的攻防项目,请使用者遵守《中华人民共和国网络安全法》,切勿用于任何非法活动,若将工具做其他用途,由使用者承担全部法律及连带责任,作者及发布者不承担任何法律连带责任项目介绍这个库是基于已经存在的MiscTool制作的,所以非常感谢rasta-mo......
  • 程序员学英文之Greetings 、Introductions &Sight-Seeing
    Greetings&IntroductionsDialogue-1Self-introduction&CompanyProfile自我介绍和公司介绍Keepalowprofile. 保持低调。It’smygreathonor tospeakheretoday.今天能在这里跟大家分享,我无比荣幸。I’veheardsomuch/alot/agreatdeal/aboutyou.......
  • Download the Vue Devtools extension for a better development experience/浏览器扩
    文章目录一、引言二、下载相关插件三、浏览器加载插件四、运行代码一、引言在做Vue项目的开发时,我们经常需要在页面上调试,若没有安装vue-devtools插件则肯能有以下报错。DownloadtheVueDevtoolsextensionforabetterdevelopmentexperience:https://githu......
  • macOS的PrivilegedHelperTools文件夹
    在 macOS 上,/Library/PrivilegedHelperTools 文件夹是一个特殊的位置,用于存放可以以更高权限运行的辅助工具或守护进程。这些工具通常由各种应用程序安装,以执行需要超出普通应用程序沙箱权限的任务,例如Proxy的应用,常见都是带有helper的应用。让我们更详细地了解这个目录及其用......
  • 「Extra」Outerside Character Intro.
    OutersideLegend人物介绍伦诺克斯Tdl泰德·都林·拉斯托雷(TedDurinLastorry)本作主角,尚未成长的伦诺克斯,实际身份是星光之首埃努诺尔的使者,初登场19岁。Tco托瑞拉·科斯特·欧瑞德(TorreillaCostelOride)强大而理智的Tco,一名合格的伦诺克斯,也是Tdl父亲的故友,实......