Vite 4.4实验性地支持Lightning CSS,Lightning CSS更快的CSS处理利器

点击在线阅读,体验更好 链接
现代JavaScript高级小册 链接
深入浅出Dart 链接
现代TypeScript高级小册 链接
lightning-css.png

Vite 4.4实验性

从Vite 4.4开始,Vite实验性地支持Lightning CSS。你可以通过在你的配置文件中添加 css.transformer: 'lightningcss' 来选择它,并安装可选的lightningcss依赖:

bash

npm add -D lightningcss

如果启用了这个选项,CSS文件将由Lightning CSS处理,而不是PostCSS。你可以将Lightning CSS选项传递给css.lightningcss 配置选项进行配置。

要配置CSS模块,你需要使用css.lightningcss.cssModules 来替代css.modules(后者用于配置PostCSS如何处理CSS模块)。

默认情况下,Vite使用esbuild来压缩CSS。 Lightning CSS也可以通过build.cssMinify: 'lightningcss' 作为CSS压缩器。

什么是Lightning CSS

[图片上传失败...(image-90a984-1688738894537)]

Lightning CSS简单理解就是Rust版本的PostCSS,然后 Lightning CSS内置了一些功能,比如 CSS压缩,语法降级,语法支持前缀,CSS模块化功能

入门Lightning CSS

使用Node

首先,使用npm或Yarn等包管理器安装Lightning CSS。

npm install --save-dev lightningcss

安装完成后,导入模块并调用Lightning CSS的API之一。transform函数将从Node Buffer编译CSS样式表。以下示例将输入的CSS进行压缩,并输出编译后的代码和源映射。

import {transform,browserslistToTargets} from "lightningcss"

import browserslist from 'browserslist';

let targets = browserslistToTargets(browserslist('>= 0.25%'));

let { code, map } = transform({
  filename: 'style.scss',
  code: Buffer.from('.foo {color: oklab(59.686% 0.1009 0.1192);;font-size:12px;margin-left:20px; }'),
  sourceMap: true,
  targets
});

console.log(code.toString())

输出:

.foo {
  color: #c65d07;
  color: lab(52.2319% 40.1449 59.9171);
  margin-left: 20px;
  font-size: 12px;
}

使用Rust

Lightning CSS也可以作为Rust库来解析、转换和压缩CSS。有关Rust API文档,请参阅docs.rs

使用Parcel

Parcel将Lightning CSS作为默认的CSS转换器。在package.json中添加一个browserslist属性,用于定义要编译CSS的目标浏览器。

虽然Lightning CSS处理了最常用的PostCSS插件,如autoprefixerpostcss-preset-env和CSS模块,但仍然需要用于像TailwindCSS这样的更自定义插件的PostCSS。在这种情况下,你的PostCSS配置将被自动识别。你可以从PostCSS配置中删除上述列出的插件,它们将由Lightning CSS处理。

你还可以在项目根目录的package.json中配置Lightning CSS。目前支持三个选项:

  • drafts,用于启用CSS嵌套和自定义媒体查询

  • pseudoClasses,允许用普通类替换某些伪类(如:focus-visible),这些类可以通过JavaScript应用(例如polyfill)

  • cssModules,用于全局启用CSS模块,而不仅限于以.module.css结尾的文件,或者接受一个选项对象。

{
  "@parcel/transformer-css": {
    "cssModules": true,
    "drafts": {
      "nesting": true,
      "customMedia": true
    },
    "pseudoClasses": {
      "focusVisible": "focus-ring"
    }
  }
}

参阅Parcel文档

使用Deno或浏览器

lightningcss-wasm包可以在Deno或直接在浏览器中使用。它使用Lightning CSS的WebAssembly构建。使用TextEncoderTextDecoder将代码从字符串转换为类型化数组,然后再转换回来。

import init, { transform } from 'https://unpkg.com/lightningcss-wasm?module';

await init();

let {code, map} = transform({
  filename: 'style.css',
  code: new TextEncoder().encode('.foo { color: red }'),
  minify: true,
});

console.log(new TextDecoder().decode(code));

请注意,WASM构建中目前不支持bundle和visitor API。

使用webpack

css-minimizer-webpack-plugin已经内置了对Lightning CSS的支持。要使用它,请使用npm或Yarn等包管理器在项目中安装Lightning CSS:

npm install --save-dev lightningcss css-minimizer-webpack-plugin browserslist

然后,配置css-minimizer-webpack-plugin以使用Lightning CSS作为压缩器。你可以使用minimizerOptions对象提供选项。有关详细信息,请参阅Transpilation

// webpack.config.js
const CssMinimizerPlugin = require('css-minimizer-webpack-plugin');
const lightningcss = require('lightningcss');
const browserslist = require('browserslist');

module.exports = {
  optimization: {
    minimize: true,
    minimizer: [
      new CssMinimizerPlugin({
        minify: CssMinimizerPlugin.lightningCssMinify,
        minimizerOptions: {
          targets: lightningcss.browserslistToTargets(browserslist('>= 0.25%'))
        },
      }),
    ],
  },
};

使用Vite

vite-plugin-lightningcss为在Vite中使用Lightning CSS提供支持。

首先,通过包管理器(如npm)将其安装到项目中:

npm install --save-dev vite-plugin-lightningcss

然后,在Vite配置中添加它。你可以向lightningcss插件传递选项,包括browserslist配置和Transpilation中记录的其他选项。

// vite.config.ts
import lightningcss from 'vite-plugin-lightningcss';

export default {
  plugins: [
    lightningcss({
      browserslist: '>= 0.25%',
    }),
  ],
};

即使使用此插件,Vite在处理和压缩CSS时仍然会内部使用PostCSS和esbuild,但它仍然是一个很好的替代方案,可以替代autoprefixer和postcss-preset-env等PostCSS插件。

使用CLI

Lightning CSS包含一个独立的CLI,用于编译、压缩和打包CSS文件。当你只需要编译CSS,而不需要来自更大的构建工具(如代码分割和对其他语言的支持)的更高级功能时,可以使用CLI。

要使用CLI,应该用npm兼容的包管理器安装lightningcss-cli包:

npm install --save-dev lightningcss-cli

然后,你可以通过npxyarn或在package.json中设置一个脚本来运行lightningcss命令。

{
  "scripts": {
    "build": "lightningcss --minify --bundle --targets '>= 0.25%' input.css -o output.css"
  }
}

查看所有可用选项,请使用--help参数:

npx lightningcss --helplightningcss

错误恢复

默认情况下,Lightning CSS是严格的,当解析无效的规则或声明时会报错。然而,有时你可能会遇到无法轻松修改的第三方库,其中包含意外包含无效语法或针对IE的hack。在这些情况下,你可以启用errorRecovery选项(或--error-recovery CLI标志)。这将跳过无效的规则和声明,在输出中省略它们,并产生警告而不是错误。

source maps

Lightning CSS支持在编译、压缩和打包源代码时生成源映射,以便更容易进行调试。使用sourceMap选项在使用API时启用它,或者使用--sourcemapCLI标志。

如果输入的CSS来自其他编译器(如Sass或Less),你还可以使用inputSourceMap API选项将输入源映射传递给Lightning CSS。这将把编译后的位置映射回原始源代码中的位置。

最后,projectRoot选项可用于使源映射中的文件路径相对于根目录。这样可以在不同的机器上保持构建的稳定性。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容