はじめに
Node.js v20.12.0でutil.styleTextが追加され、v22.13.0でStable APIとなった。これにより、ターミナルのテキスト装飾に外部パッケージが不要になるケースが増えている。
Node.js v20.12.0でutil.styleTextが追加され、v22.13.0でStable APIとなった。これにより、ターミナルのテキスト装飾に外部パッケージが不要になるケースが増えている。
util.styleTextとはnode:utilモジュールに組み込まれたテキストスタイリング関数である。ANSIエスケープシーケンスを使い、ターミナル出力に色や装飾を適用する。
import { styleText } from 'node:util';
// 単一スタイル
console.log(styleText('red', 'Error! Error!'));
// 複数スタイルの組み合わせ(配列構文)
console.log(styleText(['bold', 'underline'], 'Important message'));配列で渡した場合、左から右の順にスタイルが適用される。同系統のスタイルを複数指定すると、後のものが前のものを上書きする点に注意が必要である。
// greenが適用される(redをgreenが上書き)
console.log(styleText(['red', 'green'], 'text'));util.inspect.colorsに定義されたフォーマットを使用できる。
| グループ | スタイル |
|---|---|
| 修飾子 | reset, bold, dim, italic, underline, doubleunderline, strikethrough, hidden, overlined, blink, inverse, framed |
| 前景色 | black, red, green, yellow, blue, magenta, cyan, white, gray, redBright, greenBright, yellowBright, blueBright, magentaBright, cyanBright, whiteBright |
| 背景色 | bgBlack, bgRed, bgGreen, bgYellow, bgBlue, bgMagenta, bgCyan, bgWhite および各Brightバリアント |
対応機能:
Compatible Features:
- Basic colors (red, green, blue, yellow, etc.)
- Bright colors (redBright, greenBright, etc.)
- Background colors (bgRed, bgGreen, etc.)
- Text modifiers (bold, dim, italic, underline, strikethrough, etc.)
- Style chaining via array syntax
- Environment variable support (NO_COLOR, NODE_DISABLE_COLORS, FORCE_COLOR)
互換のない機能:
Incompatible Features:
- Custom RGB colors (chalk.rgb(), chalk.hex())
- 256-color palette (chalk.ansi256())
- Template literal syntax (chalk...``)
- Advanced modifiers with limited terminal support (overline, blink, etc.)
Chalkはメソッドチェインで複数スタイルを組み合わせる構文を持つ。
| Before(Chalk) | After(styleText) |
|---|---|
| |
picocolorsはChalkの軽量な代替として広く使われているパッケージである。パッケージサイズはChalk(101kB)に対して7kB、ロード時間もChalk(約6ms)に対して約0.5msである。PostCSS、SVGO、Stylelint、Browserslistなどで採用されている。
Chalkと異なりメソッドチェインをサポートしていない。複数スタイルの適用は関数のネストで行う。
picocolorsもstyleTextで置き換え可能な機能はChalkと同様に置き換え可能である。
| Before(picocolors) | After(styleText) |
|---|---|
| |
picocolorsのネスト構文もstyleTextのネスト構文も冗長になりがちだが、styleTextは配列構文で1要素に複数スタイルを適用する場合にまとめられる点で簡潔になる。
Node.jsプロジェクトがChalk向けの公式codemodを提供しており自動で移行もできる。ちなみにpicocolors向けのcodemodは提供されていない。
npx codemod @nodejs/chalk-to-util-styletextcodemodが処理する内容:
chalkのメソッド呼び出しをstyleTextに変換import文の書き換えpackage.jsonからのchalkパッケージの削除