前言
我们都知道,在nodejs环境下使用普通的console.log,console.error,console.info输出都是不会有颜色的,如果你不知道,那你现在知道啦"color: #ff0000">chalk使用方法
基本用法
const chalk = require('chalk') console.log(chalk.red.bold.bgWhite('Leo\'s Blog'))
上面代码执行的结果如下,Leo's Blog 加粗,字体颜色是红色,背景颜色是白色。
注意:背景颜色要在 bg 后面加上具体的颜色,颜色的第一个字母大写。
在 HTML 中支持 RGB 颜色,在这里同样支持,而且是支持所有 HTML 中支持的颜色,如十六进制颜色。这里仅仅说明十六进制颜色。
下面的代码会和上面的代码实现相同的效果。
const chalk = require('chalk') console.log(chalk.rgb(255,0,0).bold.bgRgb(255,255,255)('Leo\'s Blog'))
使用模板
该模块有一个很方便的用法就是支持模板输出,也就是说,不管在字符串中的哪个位置想改变输出的颜色,都是可以的。
const chalk = require('chalk') console.log(chalk`{red.bold.bgWhite Leo\'s Blog}`)
当然,也可以使用 RGB 颜色值。
const chalk = require('chalk') console.log(chalk`{rgb(255,0,0).bold.bgRgb(255,255,255) Leo\'s Blog}`)
常见形式
我们经常看到的警告、错误提示就是这么来的
const chalk = require('chalk') const error = chalk.bold.red; const warning = chalk.keyword('orange') console.log(error('Error!')) console.log(warning('Warning!'))
常用API
样式
- reset - 样式重置
- bold - 加粗
- dim - 浅高亮
- italic - 斜体
- underline - 下划线
- inverse- 反转前景和背景色
- hidden - 隐藏内容
- strikethrough - 删除线
- visible- 显示chalk level > 0 的内容
前景色关键字(非全支持)
- black
- red
- green
- yellow
- blue
- magenta
- cyan
- white
- blackBright (alias: gray, grey)
- redBright
- greenBright
- yellowBright
- blueBright
- magentaBright
- cyanBright
- whiteBright
背景色关键字(非全支持)
- bgBlack
- bgRed
- bgGreen
- bgYellow
- bgBlue
- bgMagenta
- bgCyan
- bgWhite
- bgBlackBright (alias: bgGray, bgGrey)
- bgRedBright
- bgGreenBright
- bgYellowBright
- bgBlueBright
- bgMagentaBright
- bgCyanBright
- bgWhiteBright
更多API可以看看官方文档。
chalk让控制台输出样式多变的原理
其原理最重要的一个知识点就是ANSI Escape code.
ASCII编码中有些字符是不能用来在终端中打印显示的,比如'\a' 0x7代表响铃,'\n' 0x0A代表换行,这些字符被称为控制符。
而其中的一个控制符 '\e' 0x1B比较特殊,这个字符代表 ESC ,即键盘上 ESC 按键的作用。ESC 是单词 escape 的缩写,即逃逸的意思。文本中出现这个控制符,表示接下来的字符是ANSI Escape code编码。
而ANSI Escape code编码中有专门控制字符颜色的控制符,例如:\e[31;44;4;1m
其意义如下:
- \e 代表开始ANSI Escape code
- [ 代表转义序列开始符 CSI,Control Sequence Introducer
- 31;44;4;1 代表以; 分隔的文本样式控制符,其中 31 代表文本前景色为红色,44代表背景为蓝色,4代表下划线,1代表加粗
- m 代表结束控制符序列
我们可以在终端中输入如下命令:
echo -e "\e[37;44;4;1mLEO\e[0m"
会有如下输出,带下划线的LEO字样:
因为 \e 控制符的16进制码为 0x1B , 8 进制码为 033 ,也可以用以下写法达到同样效果:
echo -e "\e[37;44;4;1mLEO\e[0m" echo -e "\x1b[37;44;4;1mLEO\x1b[0m" echo -e "\x1B[37;44;4;1mLEO\x1B[0m" echo -e "\033[37;44;4;1mLEO\033[0m"
通过维基百科,我查到有以下参数控制符:
代码
作用
备注
0
重置/正常
关闭所有属性。
1
粗体或增加强度
2
弱化(降低强度)
未广泛支持。
3
斜体
未广泛支持。有时视为反相显示。
4
下划线
5
缓慢闪烁
低于每分钟150次。
6
快速闪烁
MS-DOS ANSI.SYS;每分钟150以上;未广泛支持。
7
反显
前景色与背景色交换。
8
隐藏
未广泛支持。
9
划除
字符清晰,但标记为删除。未广泛支持。
10
主要(默认)字体
11–19
替代字体
选择替代字体{\displaystyle n-10}{\displaystyle n-10}。
20
尖角体
几乎无支持。
21
关闭粗体或双下划线
关闭粗体未广泛支持;双下划线几乎无支持。
22
正常颜色或强度
不强不弱。
23
非斜体、非尖角体
24
关闭下划线
去掉单双下划线。
25
关闭闪烁
27
关闭反显
28
关闭隐藏
29
关闭划除
30–37
设置前景色
参见下面的颜色表。
38
设置前景色
下一个参数是5;n或2;r;g;b,见下。
39
默认前景色
由具体实现定义(按照标准)。
40–47
设置背景色
参见下面的颜色表。
48
设置背景色
下一个参数是5;n或2;r;g;b,见下。
49
默认背景色
由具体实现定义(按照标准)。
51
Framed
52
Encircled
53
上划线
54
Not framed or encircled
55
关闭上划线
60
表意文字下划线或右边线
几乎无支持。
61
表意文字双下划线或双右边线
62
表意文字上划线或左边线
63
表意文字双上划线或双左边线
64
表意文字着重标志
65
表意文字属性关闭
重置60–64的所有效果。
90–97
设置明亮的前景色
aixterm(非标准)。
100–107
设置明亮的背景色
aixterm(非标准)。
颜色编码表如下:
名称
前景色代码
背景色代码
黑
30
40
红
31
41
绿
32
42
黄
33
43
蓝
34
44
品红
35
45
青
36
46
白
37
47
亮黑(灰)
90
100
亮红
91
101
亮绿
92
102
亮黄
93
103
亮蓝
94
104
亮品红
95
105
亮青
96
106
亮白
97
107
示例:
\e[31m 红色 \e[36;5;1;4m 缓慢闪烁的青色加粗带下划线字体
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]