雷火电竞-中国电竞赛事及体育赛事平台

歡迎來到入門教程網(wǎng)!

JavaScript

當(dāng)前位置:主頁(yè) > 網(wǎng)絡(luò)編程 > JavaScript >

如何在Node和瀏覽器控制臺(tái)中打印彩色文字

來源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:JavaScript|點(diǎn)擊:

這篇文章中,我們主要研究的是如何在Node中打印出彩色文字,瀏覽器的只是附帶。

一、常用場(chǎng)景:

1、在Wepack的打包過程中,顯示打包完成后,控制臺(tái)輸出了幾行注目的彩色文字信息。

2、在cli工具中,提示的信息有時(shí)會(huì)附帶紅色或綠色的提示。

二、瀏覽器的彩色console

在瀏覽器中,要打印彩色的log很簡(jiǎn)單,如下:

console.log('%c%s', 'color: red; font-size: 20px', 'red')
// %c代表樣式,%s代表字符串
// 樣式設(shè)置后,后面的字符串才能被渲染

那這樣子,我們是不是就可以直接挪到node上了呢?

急沖沖的挪過去一試驗(yàn),然而顯示的還是無情的白色文字。

那在Node上要怎么解決這個(gè)問題呢?

三、Shell的彩色console

1、c語言與輸出

在講Node的彩色打印前,我們先來溫習(xí)一波c語言吧。

在c語言中,\033是一個(gè)轉(zhuǎn)義字符,這里注意033表示的是8進(jìn)制的數(shù)字,表示換碼。

當(dāng)這個(gè)字符串輸出時(shí),表示對(duì)屏幕的控制。使用時(shí)可在后接一個(gè)控制字符串。

2、控制字符串組合

所有的控制字符串組合如下:

\33[0m 關(guān)閉所有屬性
\33[1m 設(shè)置高亮度
\33[4m 下劃線
\33[5m 閃爍
\33[7m 反顯
\33[8m 消隱
\33[30~37m 這個(gè)區(qū)間都可以設(shè)置字體色
\33[40~47m 這個(gè)區(qū)間都可以設(shè)置背景色
\33[90~97m 這個(gè)區(qū)間都可以設(shè)置高亮的字體色
\33[100~107m 這個(gè)區(qū)間都可以設(shè)置高亮的背景色
\33[nA 光標(biāo)上移n行
\33[nB 光標(biāo)下移n行
\33[nC 光標(biāo)右移n行
\33[nD 光標(biāo)左移n行
\33[y;xH設(shè)置光標(biāo)位置
\33[2J 清屏
\33[K 清除從光標(biāo)到行尾的內(nèi)容
\33[s 保存光標(biāo)位置
\33[u 恢復(fù)光標(biāo)位置
\33[?25l 隱藏光標(biāo)
\33[?25h 顯示光標(biāo)

3、使用例子

例1:?jiǎn)巫煮w顏色

#include <stdio.h>
int main(){
  char black[]="\033[30m black \033[0m";
  char red[]="\033[31m red \033[0m";
  char green[]="\033[32m green \033[0m";
  char yellow[]="\033[33m yellow \033[0m";
  char blue[]="\033[34m blue \033[0m";
  char popurse[]="\033[35m popurse \033[0m";
  char indigo[]="\033[36m indigo \033[0m";
  char white[]="\033[37m white \033[0m";
  printf("%s%s%s%s%s%s%s%s", black, red, green, yellow, blue, popurse, indigo, white);
  return 0;
}

例2:?jiǎn)伪尘邦伾?/p>

#include <stdio.h>
int main(){
  char black[]="\033[40m black \033[0m";
  char red[]="\033[41m red \033[0m";
  char green[]="\033[42m green \033[0m";
  char yellow[]="\033[43m yellow \033[0m";
  char blue[]="\033[44m blue \033[0m";
  char popurse[]="\033[45m popurse \033[0m";
  char indigo[]="\033[46m indigo \033[0m";
  char white[]="\033[47m white \033[0m";
  printf("%s%s%s%s%s%s%s%s", black, darkred, green, yellow, blue, popurse, indigo, white);
  return 0;
}

例3:自由組合

#include <stdio.h>
int main(){
  char mix[]="\033[31;42m blue font red bg \033[0m";
  printf("%s", mix);
  return 0;
}

四、Node的彩色打印

Node的實(shí)現(xiàn),是基于c語言的,因此Node的彩色打印其實(shí)與c語言類似。

1、console.log的實(shí)現(xiàn)

Node中的console.log的底層是process.stdout,而process.stdout的底層又是基于Stream實(shí)現(xiàn)的,再進(jìn)一步Stream的底層指向了.cc的c語言文件。到這里,大家也就明白了為什么使用c/c++的性能好了,但是,作為與系統(tǒng)最為接近的高級(jí)語言,c的強(qiáng)大和危險(xiǎn)是并存的。

2、Node的打印

知道了console.log的實(shí)現(xiàn)基礎(chǔ),我們可以大膽的輸出以下代碼:

var black="\033[30m black \033[0m";
var red="\033[31m red \033[0m";
var green="\033[32m green \033[0m";
var yellow="\033[33m yellow \033[0m";
var blue="\033[34m blue \033[0m";
var popurse="\033[35m popurse \033[0m";
var indigo="\033[36m indigo \033[0m";
var white="\033[37m white \033[0m";
console.log(black, red, green, yellow, blue, popurse, white);

毫無意外,我們打印出了彩色的log。

同樣的,按照c語言的混搭,有:

var mix="\033[37;42m white \033[0m";
console.log(mix);

除了用console.log,我們也可以直接使用process.stdout.write()實(shí)現(xiàn):

var mix="\033[37;42m white \033[0m";
process.stdout.write(mix)

3、chalk的打印

我們知道要如何實(shí)現(xiàn)了,但是我們并記不住每個(gè)符號(hào)怎么辦?

這里已經(jīng)有造好的輪子了:chalk

安裝:npm i chalk

使用:console.log(chalk.red('red'))

是不是很眼熟?你猜的沒錯(cuò),chalk.red('red')最終獲得的就是 \033[31m red \033[0m 字符串。

好了,文章到此結(jié)束,希望對(duì)正在看的你有幫助~也希望大家多多支持我們。

上一篇:JS圖片懶加載的優(yōu)點(diǎn)及實(shí)現(xiàn)原理

欄    目:JavaScript

下一篇:小程序自定義模板實(shí)現(xiàn)吸頂功能

本文標(biāo)題:如何在Node和瀏覽器控制臺(tái)中打印彩色文字

本文地址:http://www.jygsgssxh.com/a1/JavaScript/9238.html

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有