通過require('readline')
來使用這個模塊。Readline
允許逐行讀取一個流(如process.stdin
)。
注意,一旦你執(zhí)行了這個模塊,你的io.js
程序在你關(guān)閉此接口之前,將不會退出。以下是如何讓你的程序優(yōu)雅的退出的例子:
var readline = require('readline');
var rl = readline.createInterface({
input: process.stdin,
output: process.stdout
});
rl.question("What do you think of io.js? ", function(answer) {
// TODO: Log the answer in a database
console.log("Thank you for your valuable feedback:", answer);
rl.close();
});
創(chuàng)建一個readline
接口實例。接受一個options
對象,接受以下值:
input - 需要監(jiān)聽的可讀流(必選)。
output - 將逐行讀取的數(shù)據(jù)寫入的流(可選)。
completer - 用于Tab自動補全的可選函數(shù)。參閱下文的使用例子。
terminal - 如果input
和output
流需要被像一個TTY一樣對待,并且被經(jīng)由ANSI/VT100轉(zhuǎn)義代碼寫入,就傳遞true
。默認為在實例化時,檢查出的ouput
流的isTTY
值。
historySize - 保留的歷史記錄行的最大數(shù)量。默認為30
。
completer
函數(shù)被給予了一個用戶輸入的當前行,并且支持返回一個含有兩個元素的數(shù)組:
一個匹配當前輸入補全的數(shù)組。
一個被用于匹配的子字符串。
最終形式如:[[substr1, substr2, ...], originalsubstring]
。
例子:
function completer(line) {
var completions = '.help .error .exit .quit .q'.split(' ')
var hits = completions.filter(function(c) { return c.indexOf(line) == 0 })
// show all completions if none found
return [hits.length ? hits : completions, line]
}
completer
同樣也可以以同步的方式運行,如果它接受兩個參數(shù):
function completer(linePartial, callback) {
callback(null, [['123'], linePartial]);
}
createInterface
通常與process.stdin
和process.stdout
搭配,用來接受用戶輸入:
var readline = require('readline');
var rl = readline.createInterface({
input: process.stdin,
output: process.stdout
});
一旦你有了一個readline
接口,你通常要監(jiān)聽一個line
事件。
如果這個實例中,terminal
為true
。那么output
流將會得到最好的兼容性,如果它定義了output.columns
屬性,并且在output
的columns
變化時(當它是一個TTY時,process.stdout
會自動這么做),觸發(fā)了一個resize
事件。
一個代表了有input
和output
流的readline
接口。
設(shè)置提示符,例如當你在命令行運行iojs
命令時,你看到了>
,這就是io.js
的提示符。
為用戶的輸入準備好readline
,在新的一行放置當前的setPrompt
選項,給予用戶一個新的用于輸入的地方。設(shè)置preserveCursor
為true
,來防止光標位置被重置為0
。
仍會重置被createInterface
使用的input
流,如果它被暫停。
如果當調(diào)用createInterface
時output
被設(shè)置為null
或undefined
,提示符將不會被寫入。
帶著query
來預先放置提示符,并且在用戶應(yīng)答時執(zhí)行回調(diào)函數(shù)。給用戶展示query
,然后在用戶輸入了應(yīng)答后調(diào)用callback
。
仍會重置被createInterface
使用的input
流,如果它被暫停。
如果當調(diào)用createInterface
時output
被設(shè)置為null
或undefined
,什么都不會被展示。
例子:
interface.question('What is your favorite food?', function(answer) {
console.log('Oh, so your favorite food is ' + answer);
});
暫停readline
的input
流,允許它在晚些需要時恢復。
注意,帶著事件的流不會立刻被暫停。在調(diào)用了pause
后,許多事件可能被觸發(fā),包括line
事件。
恢復readline
的input
流。
關(guān)閉實例接口,放棄對input
和output
流的控制。close
事件也會被觸發(fā)。
向output
流寫入數(shù)據(jù),除非當調(diào)用createInterface
時output
被設(shè)置為null
或undefined
。key
是一個代表了鍵序列的對象;在當終端為TTY時可用。
如果input
流被暫停,它也會被恢復。
例子:
rl.write('Delete me!');
// Simulate ctrl+u to delete the line written previously
rl.write(null, {ctrl: true, name: 'u'});
當input
流收到一個\n
時觸發(fā),通常在用戶敲下回車時觸發(fā)。這是一個監(jiān)聽用戶輸入的好鉤子。
例子:
rl.on('line', function (cmd) {
console.log('You just typed: '+cmd);
});
當input
流被暫停時觸發(fā)。
也會在input
沒有被暫停并且收到一個SIGCONT
事件時觸發(fā)(參閱SIGTSTP
事件和SIGCONT
事件)。
例子:
rl.on('pause', function() {
console.log('Readline paused.');
});
當input
流被恢復時觸發(fā)。
例子:
rl.on('resume', function() {
console.log('Readline resumed.');
});
當close()
被調(diào)用時觸發(fā)。
也會在input
流收到它的end
事件時觸發(fā)。當這個事件觸發(fā)時,接口實例需要考慮“被結(jié)束”。例如,當input
流接收到^D
(也被認作EOT
)。
這個事件也會在如果當前沒有SIGINT
事件監(jiān)聽器,且input
流接收到^C
(也被認作SIGINT
)時觸發(fā)。
當input
流接收到^C
(也被認作SIGINT
)時觸發(fā)。如果當前沒有SIGINT
事件的監(jiān)聽器,pause
事件將會被觸發(fā)。
例子:
rl.on('SIGINT', function() {
rl.question('Are you sure you want to exit?', function(answer) {
if (answer.match(/^y(es)?$/i)) rl.pause();
});
});
在Windows平臺下不能使用。
當input
流接收到一個^Z
(也被認作SIGTSTP
)時觸發(fā)。如果當前沒有SIGTSTP
事件的監(jiān)聽器,這個程序?qū)凰椭梁笈_運行。
當程序使用fg
恢復,pause
和SIGCONT
事件都會被觸發(fā)。你可以選擇其中的一個來恢復流。
如果流在程序被送至后臺前就被暫停,pause
和SIGCONT
事件將不會觸發(fā)。
例子:
rl.on('SIGTSTP', function() {
// This will override SIGTSTP and prevent the program from going to the
// background.
console.log('Caught SIGTSTP.');
});
在Windows平臺下不能使用。
當input
流被^Z
(也被認作SIGTSTP
)送至后臺時觸發(fā),然后使用fg(1)
繼續(xù)執(zhí)行。這個事件僅在程序被送至后臺前流沒有被暫停時觸發(fā)。
例子:
rl.on('SIGCONT', function() {
// `prompt` will automatically resume the stream
rl.prompt();
});
下面是一個使用以上方法來創(chuàng)建一個迷你的控制臺接口的例子:
var readline = require('readline'),
rl = readline.createInterface(process.stdin, process.stdout);
rl.setPrompt('OHAI> ');
rl.prompt();
rl.on('line', function(line) {
switch(line.trim()) {
case 'hello':
console.log('world!');
break;
default:
console.log('Say what? I might have heard `' + line.trim() + '`');
break;
}
rl.prompt();
}).on('close', function() {
console.log('Have a great day!');
process.exit(0);
});
在給定的TTY流中,將光標移動到指定位置。
在給定的TTY流中,相對于當前位置,將光標移動到指定位置。
用指定的方式,在給定的TTY流中,清除當前的行。dir
可以是以下值之一:
從當前的光標位置,清除屏幕。
更多建議: