js用readline模块实现输入输出_node

什么是Readline

Readline是Node.js里实现标准输入输出的封装好的模块,通过这个模块我们可以以逐行的方式读取数据流。使用require可以引用模块。

如何使用Readline

以使用为角度的话,学习Readline,我们需要学习它的三个部分:

创建Readline实例 学习里面的接口方法 学习监听与处理Readline事件

下面我们通过实例来学习这三个部分。

实例1:我叫小明

代码如下:

/** * Created by Administrator on 2015/9/10. */// 引入readline模块var readline = require;//创建readline接口实例var rl = readline.createInterface({ input:process.stdin, output:process.stdout});// question方法rl.question("你叫什么?",function{ console.log; // 不加close,则不会结束 rl.close;// close事件监听rl.on{ // 结束程序 process.exit;

上面的实例用到了我们需要学习到的三个部分,首先使用了createInterface创建了一个接口实例,然后使用了question方法来询问姓名,最后是监听readline金沙网址,的close事件,因为无论是方法名和事件的监听的名字都比较直观,关于它们的作用也能一目了然,我这里就只提了三点需要注意的:

createInterface里,我们需要传入标准输入输出作为数据的输入输出流
question方法的回调函数里,我们可以获取到用户的输入并进行处理,同时我们进行了close操作来结束程序,否则程序不会结束
close事件的监听里,我们执行了process.exit来使程序退出的操作,因为readline模块只要一开始获取用户输入就不会结束,必须使用这种直接的方式来结束程序

实例2:输入与输出

/** * Created by Administrator on 2015/9/10. */// 引入readline模块var readline = require;var rl = readline.createInterface({ input: process.stdin, output: process.stdout});rl.on('line', function{ switch { case 'copy': console.log; break; case 'hello': rl.write; console.log; break; case 'close': rl.close(); break; default: console.log; break; }});rl.on { console.log; process.exit;

‘line’事件,这个事件就是在用户输完一行,按下回车后就会触发的事件,它会将用户输入的数据通过回调函数传回来,可在此方法里处理用户输入的数据

实例3:类似命令行的输入输出

var readline = require; var rl = readline.createInterface(process.stdin, process.stdout);rl.setPrompt; rl.prompt();rl.on('line', function { switch { case 'copy': console.log; break; case 'hello': console.log; break; case 'close': rl.close(); break; default: console.log; break; } rl.prompt;rl.on { console.log; process.exit;

这个实例里出现了两个新方法

方法setPromat,就是给每一行设置一个提示符,就好比window命令行的>
,我们这里设置的是Test>
promat()可以算是最重要的方法了,因为它才体现了Readline的核心作用,以行为单位读取数据,premat方法就是在等待用户输入数据
这里又监听了’line’
事件,因为promat方法调用一次就只会读取一次数据,所以,在这个方法又调用了一次promat方法,这样就可以继续读取用户输入,从而达到一种命令行的效果

附录

这里只写了三个比较简单的例子来说明Readline的使用,如果还想要了解更多的关于Readline的用法以及更多的方法和事件,可以去看官方的API

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

发表评论

电子邮件地址不会被公开。 必填项已用*标注