亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

nodejs控制臺(tái)打印高亮代碼的實(shí)現(xiàn)方法

 更新時(shí)間:2021年05月11日 12:08:07   作者:神說(shuō)要有光zxg  
這篇文章主要給大家介紹了關(guān)于nodejs控制臺(tái)打印高亮代碼的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

當(dāng)代碼運(yùn)行報(bào)錯(cuò)時(shí),我們會(huì)打印錯(cuò)誤,錯(cuò)誤中有堆棧信息,可以定位到對(duì)應(yīng)的代碼位置。但有的時(shí)候我們希望能夠更直接準(zhǔn)確的打印報(bào)錯(cuò)位置的代碼。比如這樣:

這個(gè)可以使用 @babel/code-frames 來(lái)做到:

const { codeFrameColumns } = require('@babel/code-frame');

const res = codeFrameColumns(code, {
  start: { line: 2, column: 1 },
  end: { line: 3, column: 5 },
}, {
  highlightCode: true,
  message: '這里出錯(cuò)了'
});

console.log(res);

有沒(méi)有感覺(jué)比較神奇,它是怎么做到的打印出上面的代碼格式的(code frame)?

本文我們就來(lái)探究下原理。

主要會(huì)解答三個(gè)問(wèn)題:

  • 如何打印出標(biāo)記相應(yīng)位置代碼的 code frame(就是上圖的打印格式)
  • 如何實(shí)現(xiàn)語(yǔ)法高亮
  • 如何在控制臺(tái)打印顏色

如何打印 code frame

我們先不管高亮,實(shí)現(xiàn)這樣的格式的打?。?/p>

有啥思路沒(méi)?

其實(shí)也比較容易想到,傳入了源代碼、標(biāo)記開始和結(jié)束的行列號(hào),那么我們就能夠計(jì)算出顯示標(biāo)記(marker)的行是哪些,以及這些行的哪些列,然后依次對(duì)每一行代碼做處理,如果本行沒(méi)有標(biāo)記則保持原樣,如果本行有標(biāo)記的話,那么就在開始打印一個(gè) marker “>”,并且在下面打印一行 marker "^",最后一個(gè)標(biāo)記行還要打印錯(cuò)誤信息。

我們來(lái)看一下 @babel/code-frame 的實(shí)現(xiàn):

首先,分割字符串成每一行的數(shù)組,然后根據(jù)傳入的位置計(jì)算出 marker 所在的位置。

比如圖中第二行的第 1 到 12 列,第三行的 0 到 5 列。

然后對(duì)每一行做處理,如果本行有標(biāo)記,則拼成 marker + gutter(行號(hào)) + 代碼的格式,下面再打印一行 marker,最后的 marker 行打印 message。沒(méi)有標(biāo)記不處理。

這樣最終拼出的就是這樣的 code frame:

我們實(shí)現(xiàn)了 code frame 的拼接,暫時(shí)忽略了高亮,那么怎么做語(yǔ)法高亮呢?

如何實(shí)現(xiàn)語(yǔ)法高亮

實(shí)現(xiàn)語(yǔ)法高亮需要理解代碼,但是如果只是高亮,詞法分析就足夠了。babel 也是這么做的,@babel/highlight 包里面完成了高亮代碼的邏輯。

先看效果:

const a = 1;
const b = 2;
console.log(a + b);

上面的源碼被分成了 token 數(shù)組:

[
  [ 'whitespace', '\n' ], [ 'keyword', 'const' ],
  [ 'whitespace', ' ' ],  [ 'name', 'a' ],
  [ 'whitespace', ' ' ],  [ 'punctuator', '=' ],
  [ 'whitespace', ' ' ],  [ 'number', '1' ],
  [ 'punctuator', ';' ],  [ 'whitespace', '\n' ],
  [ 'keyword', 'const' ], [ 'whitespace', ' ' ],
  [ 'name', 'b' ],        [ 'whitespace', ' ' ],
  [ 'punctuator', '=' ],  [ 'whitespace', ' ' ],
  [ 'number', '2' ],      [ 'punctuator', ';' ],
  [ 'whitespace', '\n' ], [ 'name', 'console' ],
  [ 'punctuator', '.' ],  [ 'name', 'log' ],
  [ 'bracket', '(' ],     [ 'name', 'a' ],
  [ 'whitespace', ' ' ],  [ 'punctuator', '+' ],
  [ 'whitespace', ' ' ],  [ 'name', 'b' ],
  [ 'bracket', ')' ],     [ 'punctuator', ';' ],
  [ 'whitespace', '\n' ]
]

token 怎么分的呢?

一般來(lái)說(shuō)詞法分析就是有限狀態(tài)自動(dòng)機(jī)(DFA),但是這里實(shí)現(xiàn)比較簡(jiǎn)單,是通過(guò)正則匹配的:

js-tokens 這個(gè)包暴露出來(lái)一個(gè)正則,一個(gè)函數(shù),正則是用來(lái)識(shí)別 token 的,其中有很多個(gè)分組,而函數(shù)里面是對(duì)不同的分組下標(biāo)返回了不同的類型,這樣就能完成 token 的識(shí)別和分類。

在 @babel/highlight 包里也是這樣用的:

(正則來(lái)做詞法分析有很多限制條件,比如不能處理遞歸的情況,所以這種方式不是通用的,通用詞法分析還是得用狀態(tài)機(jī) DFA。)

有了分類之后,不同 token 顯示不同顏色,建立個(gè) map 就行了。

@babel/highlight 也是這么做的:

我們知道了怎么做語(yǔ)法高亮,使用 chalk 的 api 就可以打印顏色,那控制臺(tái)打印顏色的原理是什么呢?

如何在控制臺(tái)打印顏色

控制臺(tái)打印的是 ASCII 碼,并不是所有的編碼都對(duì)應(yīng)可見字符,ASCII 碼有一部分字符是對(duì)應(yīng)控制字符的,比如 27 是 ESC,就是我們鍵盤上的 ESC 鍵,是 escape 的縮寫,按下它可以完成一些控制功能,這里我們可以通過(guò)打印 ESC 的 ASCII 碼來(lái)進(jìn)入控制打印顏色的狀態(tài)。

格式是這樣的:

打印一個(gè) ESC 的 ASCII 碼,之后是 [ 代表開始,m 代表結(jié)束,中間是用 ; 分隔的 n 個(gè)控制字符,可以控制很多樣式,比如前景色、背景色、加粗、下劃線等等。

ESC 的 ASCII 碼是 27,有好幾種寫法:一種是字符表示的 \e ,一種是 16 進(jìn)制的 \0x1b(27 對(duì)應(yīng)的 16進(jìn)制),一種是 8 進(jìn)制的 \033,這三種都表示 ESC。

我們來(lái)試驗(yàn)一下:1 表示加粗、36 表示前景色為青色、4 表示下劃線,下面三種寫法等價(jià):

\e[36;1;4m
\033[36;1;4m
\0x1b[36;1;4m

我們來(lái)試一下:

圖片都打印了正確的樣式!

當(dāng)然,加了樣式還要去掉,可以加一個(gè) \e[0m 就可以了(\033[0m,\0x1b[0m 等價(jià))。

chalk(nodejs 的在終端打印顏色的庫(kù))的不同方法就是封裝了這些 ASCII 碼的顏色控制字符。

上面每行代碼被高亮過(guò)以后的代碼是:

這樣也就實(shí)現(xiàn)了不同顏色的打印。

總結(jié)

至此,我們能實(shí)現(xiàn)開頭的效果了:支持 code frame 的打印,支持語(yǔ)法高亮,能夠打印顏色

本文我們探究了這種效果的實(shí)現(xiàn)原理,先從 code frame 是怎么拼接的,然后每一行的代碼是怎么做高亮的,之后是高亮具體是怎么打印顏色的。

不管是 code frame 的打印,還是語(yǔ)法高亮或者控制臺(tái)打印顏色,都是特別常見的功能,希望這篇文章能夠幫你徹底掌握這 3 方面的原理。

到此這篇關(guān)于nodejs控制臺(tái)打印高亮代碼的文章就介紹到這了,更多相關(guān)nodejs控制臺(tái)打印高亮內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Node.js中參數(shù)傳遞的兩種方式詳解

    Node.js中參數(shù)傳遞的兩種方式詳解

    這篇文章主要為大家介紹了Node.js中參數(shù)傳遞的兩種方式:GET方式和POST方式,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2022-04-04
  • node實(shí)現(xiàn)簡(jiǎn)單的反向代理服務(wù)器

    node實(shí)現(xiàn)簡(jiǎn)單的反向代理服務(wù)器

    本篇文章主要介紹了node實(shí)現(xiàn)簡(jiǎn)單的反向代理,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-07-07
  • nodejs控制臺(tái)打印高亮代碼的實(shí)現(xiàn)方法

    nodejs控制臺(tái)打印高亮代碼的實(shí)現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于nodejs控制臺(tái)打印高亮代碼的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • node-gyp安裝vuetify編譯失敗gyp?ERR的問(wèn)題及解決

    node-gyp安裝vuetify編譯失敗gyp?ERR的問(wèn)題及解決

    這篇文章主要介紹了node-gyp安裝vuetify編譯失敗gyp?ERR的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Npm link的作用與使用示例代碼

    Npm link的作用與使用示例代碼

    npm link可以幫助我們模擬包安裝后的狀態(tài),它會(huì)在系統(tǒng)中做一個(gè)快捷方式映射,讓本地的包就好像 install 過(guò)一樣,可以直接使用,這篇文章主要介紹了Npm link的作用與使用示例代碼,需要的朋友可以參考下
    2023-01-01
  • npm報(bào)錯(cuò)"A?complete?log?of?this?run?can?be?found?in:"的解決辦法

    npm報(bào)錯(cuò)"A?complete?log?of?this?run?can?be?found?

    這篇文章主要給大家介紹了關(guān)于npm報(bào)錯(cuò)"A?complete?log?of?this?run?can?be?found?in:"的解決辦法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-04-04
  • Nodejs處理異常操作示例

    Nodejs處理異常操作示例

    這篇文章主要介紹了Nodejs處理異常操作,結(jié)合實(shí)例形式分析了nodejs針對(duì)異常的捕獲與處理相關(guān)操作技巧,需要的朋友可以參考下
    2018-12-12
  • 使用Node.js實(shí)現(xiàn)獲取視頻詳情

    使用Node.js實(shí)現(xiàn)獲取視頻詳情

    這篇文章主要為大家詳細(xì)介紹了如何在Node.js應(yīng)用程序中實(shí)現(xiàn)獲取視頻詳情的功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-04-04
  • nvm使用use命令失效問(wèn)題解決方法

    nvm使用use命令失效問(wèn)題解決方法

    這篇文章主要給大家介紹了關(guān)于nvm使用use命令失效問(wèn)題的解決方法,nvm是一個(gè)類似于版本管理工具的軟件,它可以輕松地在同一臺(tái)計(jì)算機(jī)上管理多個(gè)不同的node.js版本,需要的朋友可以參考下
    2023-07-07
  • Node.js入門教程:在windows和Linux上安裝配置Node.js圖文教程

    Node.js入門教程:在windows和Linux上安裝配置Node.js圖文教程

    這篇文章主要介紹了Node.js入門教程:在windows和Linux上安裝配置Node.js的方法,本文圖文并茂,步驟明細(xì),是學(xué)習(xí)安裝node.js的絕佳教程,需要的朋友可以參考下
    2014-08-08

最新評(píng)論