picocolors:终端输出美化的极简利器,快如闪电的ANSIColor库!

前言

在开发命令行工具或Node.js应用时,终端输出的可读性和美观性往往决定了用户体验。而今天推荐的 picocolors 正是当前最轻量、性能最强的终端颜色格式化库!它仅有 0.5KB 大小,比同类库(如chalk)快2倍,且无需任何依赖,成为PostCSS、SVGO等流行工具的首选。

为什么选择picocolors?

1. 极致的轻量与性能

  • 体积仅0.5KB :比chalk小14倍,对项目体积几乎无影响。
  • 速度领先:通过优化的ANSI转义序列生成,执行效率碾压多数同类库。
  • 零依赖:无需额外安装模块,开箱即用。

2. 全功能支持

  • 文字颜色 :支持blackredgreen等8种基础色,以及gray
  • 背景色 :通过bgRedbgGreen等实现高亮显示。
  • 格式修饰bold(加粗)、italic(斜体)、underline(下划线)等丰富样式。

3. 开发者友好

  • TypeScript支持:内置类型声明,完美兼容TS项目。
  • 跨平台兼容:支持Node.js 6+和浏览器环境。

快速上手指南

安装

通过npm或pnpm一键安装:

shell 复制代码
npm install picocolors
# 或
pnpm add picocolors

基础使用

javascript 复制代码
import pc from 'picocolors';

console.log(pc.green('成功!'));           // 绿色文字
console.log(pc.bgRed('错误警告'));        // 红色背景
console.log(pc.bold(pc.cyan('重要信息'))); // 加粗青色

高级组合

javascript 复制代码
// 嵌套样式
console.log(pc.red(`错误:${pc.bold('文件未找到')}`));

// 艺术字与多色混搭
console.log(pc.bold(pc.green(`欢迎使用 ${pc.blue('Vite')}!`)));

举一些例子

示例 1:嵌套样式组合

javascript 复制代码
import pc from 'picocolors'

// 嵌套样式(加粗 + 颜色 + 背景)
const title = pc.bold(pc.bgWhite(pc.black(' 系统状态 ')))
const message = pc.red(`发现 ${pc.underline('3 个')} 待处理问题!`)
console.log(`${title}\n${message}`)

// 多色混合文本
console.log(pc.green('欢迎使用') + pc.blue(' Node.js ') + pc.magenta('CLI 工具'))

应用场景:命令行工具的状态提示或交互界面美化

示例 2:动态生成彩色日志

javascript 复制代码
import pc from 'picocolors'

function logStatus(text, type = 'info') {
  const colorMap = {
    info: pc.blue,
    success: pc.green,
    warn: pc.yellow,
    error: pc.red,
  }
  const symbol = type === 'error' ? '✖' : '✔'
  console.log(colorMap[type](`[${symbol}] ${text}`))
}

logStatus('文件保存成功', 'success') // 绿色输出
logStatus('无法连接服务器', 'error') // 红色输出

示例 3:ASCII 艺术字

javascript 复制代码
import pc from 'picocolors'

const logo = pc.bold(
  pc.green(`
   ██████╗ ██╗   ██╗██████╗ 
  ██╔════╝ ██║   ██║██╔══██╗
  ██║  ███╗██║   ██║██████╔╝
  ██║   ██║██║   ██║██╔══██╗
  ╚██████╔╝╚██████╔╝██║  ██║
   ╚═════╝  ╚═════╝ ╚═╝  ╚═╝
  `)
)
console.log(logo)

示例 4:进度条模拟

javascript 复制代码
import pc from 'picocolors'

function simulateProgress() {
  let progress = 0
  const interval = setInterval(() => {
    progress += 10
    const bar = '■'.repeat(progress / 10).padEnd(10, '□')
    // process.stdout.write 可以在同一行输出内容
    process.stdout.write(pc.cyan(`\r[${bar}] ${progress}%`)) // 使用 \r 覆盖同一行
    if (progress >= 100) {
      clearInterval(interval)
      console.log() // 输出换行,避免光标停留在进度条末尾
    }
  }, 500)
}
simulateProgress()

总结

picocolors极简设计强悍性能,成为终端美化的新标杆。无论是开发CLI工具、日志系统,还是优化现有项目,它都能以最小的代价带来显著的体验提升。快来尝试,让你的命令行输出"色"彩斑斓!

🔥 关注我的公众号「哈希茶馆」一起交流更多开发技巧

相关推荐
2501_920931702 分钟前
React Native鸿蒙跨平台使用useState管理健康记录和过滤状态,支持多种健康数据类型(血压、体重等)并实现按类型过滤功能
javascript·react native·react.js·ecmascript·harmonyos
Ulyanov11 分钟前
从静态到沉浸:打造惊艳的Web技术发展历程3D时间轴
前端·javascript·html5·gui开发
VT.馒头35 分钟前
【力扣】2625. 扁平化嵌套数组
前端·javascript·算法·leetcode·职场和发展·typescript
毎天要喝八杯水1 小时前
搭建vue前端后端环境
前端·javascript·vue.js
雨季6662 小时前
Flutter 三端应用实战:OpenHarmony “极简手势轨迹球”——指尖与屏幕的诗意对话
开发语言·javascript·flutter
摘星编程3 小时前
OpenHarmony环境下React Native:Tooltip自动定位
javascript·react native·react.js
穿过锁扣的风3 小时前
如何操作HTML网页
前端·javascript·html
2601_949833394 小时前
flutter_for_openharmony口腔护理app实战+知识实现
android·javascript·flutter
东东5164 小时前
果园预售系统的设计与实现spingboot+vue
前端·javascript·vue.js·spring boot·个人开发
起风的蛋挞4 小时前
Matlab提示词语法
前端·javascript·matlab