Node.js API詳解之 repl模塊用法實例分析
本文實例講述了Node.js API詳解之 repl模塊用法。分享給大家供大家參考,具體如下:
Node.js API詳解之 repl
repl(交互式解釋器) 模塊提供了一種“讀取-求值-輸出”循環(huán)(REPL)的實現(xiàn),它可作為一個獨立的程序或嵌入到其他應(yīng)用中。
可以通過以下方式使用它:
const repl = require('repl');
Node.js 自身也使用 repl 模塊為執(zhí)行 JavaScript 代碼提供交互接口。
可以通過不帶任何參數(shù)(或使用 -i 參數(shù))地執(zhí)行 Node.js 二進(jìn)制文件來使用它:
$ node
> const a = [1, 2, 3];
undefined
> a
[ 1, 2, 3 ]
> a.forEach((v) => {
... console.log(v);
... });
1
2
3
repl.start([options])
說明:
該屬性的值為當(dāng)前系統(tǒng)的路徑分隔符。Windows下是:”;“ POSIX下是:”:“
repl.start() 方法創(chuàng)建并啟動一個 repl.REPLServer 實例。
如果 options 是一個字符串,則它指定了輸入提示符:
options:
prompt:要顯示的輸入提示符。默認(rèn)為 >(末尾有一個空格)
input:REPL 輸入要被讀取的可讀流。默認(rèn)為 process.stdin
output:REPL 輸出要被寫入的可寫流。默認(rèn)為 process.stdout
terminal:如果為 true,則指定 output 應(yīng)被當(dāng)作一個 TTY 終端,并且可以使用 ANSI/VT100 轉(zhuǎn)義碼寫入。 默認(rèn)值為初始化時 output 流的 isTTY 屬性的值。
eval: 當(dāng)解釋每行輸入時使用的函數(shù)。默認(rèn)為 JavaScript eval() 函數(shù)的異步封裝。 eval 函數(shù)出錯時會返回 repl.Recoverable,表明輸入不完整并提示用戶完成輸入
useColors:如果為 true,則指定默認(rèn)的 writer 函數(shù)可以在 REPL 輸出中包含 ANSI 顏色風(fēng)格。 如果提供了自定義的 writer 函數(shù),則該參數(shù)無效。 默認(rèn)為 REPL 實例的 terminal 屬性的值。
useGlobal:如果為 true,則指定默認(rèn)的解釋函數(shù)使用 JavaScript global 作為上下文,而不是為 REPL 實例創(chuàng)建一個新的獨立的上下文。
ignoreUndefined:如果為 true,則指定默認(rèn)的輸出器不會輸出命令返回的 undefined 值。 默認(rèn)為 false。
writer:寫入到 output 之前,該函數(shù)被調(diào)用用來格式化每個命令的輸出。 默認(rèn)為 util.inspect()。
completer:選的函數(shù),用來自定義 Tab 鍵的自動補全。
breakEvalOnSigint:當(dāng)接收到 SIGINT 時停止解釋當(dāng)前代碼,比如按下 Ctrl+C。 不能與自定義的 eval 函數(shù)同時使用。 默認(rèn)為 false。
replMode:個標(biāo)志位,指定默認(rèn)的解釋器使用嚴(yán)格模式或默認(rèn)(sloppy)模式來執(zhí)行 JavaScript 命令。 可選的值有:
repl.REPL_MODE_SLOPPY – 使用默認(rèn)模式解釋表達(dá)式。
repl.REPL_MODE_STRICT – 使用嚴(yán)格模式解釋表達(dá)式。該模式等同于在每個 repl 聲明前加上 ‘use strict'
repl.REPL_MODE_MAGIC – 不推薦使用
如果 options 是一個字符串,則它指定了輸入提示符
demo:
const repl = require('repl');
// 一個 Unix 風(fēng)格的提示符
repl.start('$ ');
REPLServer 類
說明:
該屬性的值為當(dāng)前系統(tǒng)的路徑分隔符。Windows下是:”;“ POSIX下是:”:“
repl.REPLServer 類繼承自 readline.Interface 類。
repl.REPLServer 的實例由 repl.start() 方法創(chuàng)建,不能直接使用 JavaScript 的 new 關(guān)鍵字創(chuàng)建。
replServer.defineCommand(keyword, cmd)
說明:
該屬性的值為當(dāng)前系統(tǒng)的路徑分隔符。Windows下是:”;“ POSIX下是:”:“
replServer.defineCommand() 方法用于添加新的前綴為 . 的命令到 REPL 實例。
這些命令通過輸入一個 . 加 keyword 來調(diào)用。 cmd 可以是一個函數(shù)或一個具有以下屬性的對象:
help:當(dāng)鍵入 .help 時顯示的幫助說明(可選)。
action:要執(zhí)行的函數(shù),可接受一個字符串參數(shù)。
demo:
const repl = require('repl');
const replServer = repl.start({ prompt: '> ' });
replServer.defineCommand('sayhello', {
help: '打招呼',
action(name) {
this.lineParser.reset();
this.bufferedCommand = '';
console.log(`你好,${name}!`);
this.displayPrompt();
}
});
replServer.defineCommand('saybye', function saybye() {
console.log('再見!');
this.close();
});
replServer.displayPrompt([preserveCursor])
說明:
該屬性的值為當(dāng)前系統(tǒng)的路徑分隔符。Windows下是:”;“ POSIX下是:”:“
replServer.displayPrompt() 方法會讓 REPL 實例做好用戶輸入的準(zhǔn)備,打印配置的 prompt 到 output 中新的一行,然后返回 input 等待新的輸入。
當(dāng)正在鍵入多行輸入時,會打印省略號而不是提示符。
當(dāng) preserveCursor 為 true 時,游標(biāo)位置不會被復(fù)位到 0。
replServer.displayPrompt 方法主要被使用 replServer.defineCommand() 方法注冊的命令的 action 函數(shù)調(diào)用。
reset 事件
說明:
該屬性的值為當(dāng)前系統(tǒng)的路徑分隔符。Windows下是:”;“ POSIX下是:”:“
當(dāng) REPL 的上下文被重置時,觸發(fā) ‘reset' 事件。
每當(dāng)接收到 .clear 命令時會觸發(fā)該事件,除非 REPL 正在使用默認(rèn)的解釋器并且 repl.REPLServer 實例被創(chuàng)建時 useGlobal 選項被設(shè)為 true。
監(jiān)聽器的回調(diào)函數(shù)被調(diào)用時會帶上 context 對象作為惟一的參數(shù)。
這主要被用于重新初始化 REPL 上下文,使之達(dá)到某些預(yù)定義的狀態(tài),如下面的例子:
demo:
const repl = require('repl');
function initializeContext(context) {
context.m = 'test';
}
const r = repl.start({ prompt: '> ' });
initializeContext(r.context);
r.on('reset', initializeContext);
// $ ./node example.js
// > m
// 'test'
// > m = 1
// 1
// > m
// 1
// > .clear
// Clearing context...
// > m
// 'test'
// >
exit 事件
說明:
該屬性的值為當(dāng)前系統(tǒng)的路徑分隔符。Windows下是:”;“ POSIX下是:”:“
當(dāng)接收到 .exit 命令、或按下兩次 ctrl + C 發(fā)出 SIGINT 信號、或按下 ctrl+D 發(fā)出 ‘end' 信號而使 REPL 被退出時,
觸發(fā) ‘exit' 事件。 監(jiān)聽器的回調(diào)函數(shù)被調(diào)用時不帶任何參數(shù)。
demo:
replServer.on('exit', () => {
console.log('從 REPL 接收到 "exit" 事件!');
process.exit();
});
命令與特殊鍵
說明:
該屬性的值為當(dāng)前系統(tǒng)的路徑分隔符。Windows下是:”;“ POSIX下是:”:“
所有 REPL 的實例都支持下列特殊命令:
.break – 在輸入一個多行表達(dá)式的過程中,輸入 .break 命令(或按下 ctrl-C 組合鍵)將終止表達(dá)式的繼續(xù)輸入。
.clear – 重置 REPL 的 context 為一個空對象,并清除當(dāng)前正輸入的所有多行表達(dá)式。
.exit – 關(guān)閉輸入輸出流,退出 REPL。
.help – 顯示特定命令的幫助列表。
.save – 保存當(dāng)前 REPL 會話到一個文件: > .save ./file/to/save.js
.load – 讀取一個文件到當(dāng)前 REPL 會話。 > .load ./file/to/load.js
.editor 進(jìn)入編輯模式(ctrl-D 完成,ctrl-C 取消)
REPL 中下列按鍵組合有特殊作用:
ctrl + C – 當(dāng)按下一次時,與 .break 命令的效果一樣。當(dāng)在空白行按下兩次時,與 .exit 命令的效果一樣。
ctrl + D – 與 .exit 命令的效果一樣。
tab – 當(dāng)在空白行按下時,顯示全局和本地作用域內(nèi)的變量。當(dāng)在輸入時按下,顯示相關(guān)的自動補全選項。
demo:
> .editor
// 進(jìn)入編輯模式(^D 完成,^C 取消)
function welcome(name) {
return `你好 ${name}!`;
}
welcome('Node.js 用戶');
// ^D
'你好 Node.js 用戶!'
>
自定義的解釋函數(shù)
說明:
該屬性的值為當(dāng)前系統(tǒng)的路徑分隔符。Windows下是:”;“ POSIX下是:”:“
當(dāng)創(chuàng)建一個新的 repl.REPLServer 時,可以提供一個自定義的解釋函數(shù)。 這可以用于實現(xiàn)完全定制化的 REPL 應(yīng)用。
例子,一個執(zhí)行文本翻譯的 REPL:
demo:
const repl = require('repl');
const { Translator } = require('translator');
const myTranslator = new Translator('en', 'fr');
function myEval(cmd, context, filename, callback) {
callback(null, myTranslator.translate(cmd));
}
repl.start({ prompt: '> ', eval: myEval });
自定義 REPL 輸出
說明:
該屬性的值為當(dāng)前系統(tǒng)的路徑分隔符。Windows下是:”;“ POSIX下是:”:“
默認(rèn)情況下,在把輸出寫入到提供的可寫流(默認(rèn)為 process.stdout)之前,
repl.REPLServer 實例會使用 util.inspect() 方法對輸出進(jìn)行格式化。
使用 util.inspect() 方法時,useColors 選項可被指定是否在建立默認(rèn)輸出器時使用 ANSI 風(fēng)格的代碼給輸出上色。
在構(gòu)造時,通過在 writer 選項傳入一個新的函數(shù),可以完全地自定義一個 repl.REPLServer 實例的輸出。
例子,把輸入的任何文本轉(zhuǎn)換為大寫:
demo:
const repl = require('repl');
const r = repl.start({ prompt: '> ', eval: myEval, writer: myWriter });
function myEval(cmd, context, filename, callback) {
callback(null, cmd);
}
function myWriter(output) {
return output.toUpperCase();
}
希望本文所述對大家node.js程序設(shè)計有所幫助。
相關(guān)文章
Node層模擬實現(xiàn)multipart表單的文件上傳示例
下面小編就為大家分享一篇Node層模擬實現(xiàn)multipart表單的文件上傳示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01
iOS + node.js使用Socket.IO框架進(jìn)行實時通信示例
本篇文章主要介紹了iOS + node.js使用Socket.IO框架進(jìn)行實時通信示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-04-04
詳解nodejs微信公眾號開發(fā)——3.封裝消息響應(yīng)模塊
上一篇文章:nodejs微信公眾號開發(fā)(2)自動回復(fù),實現(xiàn)了簡單的關(guān)注回復(fù)。采用拼接字符串的形式,并不是很方便,這里我們將其封裝承接口。2017-04-04

