Node.js用readline模块实现输入输出


Posted in Javascript onDecember 16, 2016

什么是Readline

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

如何使用Readline

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

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

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

实例1:我叫小明

代码如下:

/**
 * Created by Administrator on 2015/9/10.
 */
// 引入readline模块
var readline = require('readline');

//创建readline接口实例
var rl = readline.createInterface({ 
 input:process.stdin,
 output:process.stdout
});

// question方法
rl.question("你叫什么?",function(answer){ 
 console.log("名字是:"+answer);
 // 不加close,则不会结束
 rl.close();
});

// close事件监听
rl.on("close", function(){ 
 // 结束程序
 process.exit(0);
});

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

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

实例2:输入与输出

/**
 * Created by Administrator on 2015/9/10.
 */
// 引入readline模块
var readline = require('readline');

var rl = readline.createInterface({ 
 input: process.stdin,
 output: process.stdout
});

rl.on('line', function(line){ 
 switch(line.trim()) {
  case 'copy':
   console.log("复制");
   break;
  case 'hello':
   rl.write("Write");
   console.log('world!');
   break;
  case 'close':
   rl.close();
   break;
  default:
   console.log('没有找到命令!');
   break;
 }
});
rl.on('close', function() { 
 console.log('bye bye');
 process.exit(0);
});

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

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

var readline = require('readline'); 
var rl = readline.createInterface(process.stdin, process.stdout);

rl.setPrompt('Test> '); 
rl.prompt();

rl.on('line', function(line) { 
 switch(line.trim()) {
  case 'copy':
   console.log("复制");
   break;
  case 'hello':
   console.log('world!');
   break;
  case 'close':
   rl.close();
   break;
  default:
   console.log('没有找到命令!');
   break;
 }
 rl.prompt();
});

rl.on('close', function() { 
 console.log('bye bye!');
 process.exit(0);
});

运行截图如下:

Node.js用readline模块实现输入输出

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

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

附录

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

总结

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

Javascript 相关文章推荐
JavaScript基础篇之变量作用域、传值、传址的简单介绍与实例
Jun 29 Javascript
图标线性回归斜着移动到指定的位置
Aug 16 Javascript
javascript模拟实现C# String.format函数功能代码
Nov 25 Javascript
两个多选select(multiple左右)添加、删除选项和取值实例
May 12 Javascript
js获取表格的行数和列数的方法
Oct 23 Javascript
每天一篇javascript学习小结(Date对象)
Nov 13 Javascript
JavaScript高级教程5.6之基本包装类型(详细)
Nov 23 Javascript
js基本算法:冒泡排序,二分查找的简单实例
Oct 08 Javascript
JS函数节流和函数防抖问题分析
Dec 18 Javascript
express+mockjs实现模拟后台数据发送功能
Jan 07 Javascript
js判断输入框不能为空格或null值的实现方法
Mar 02 Javascript
Vue使用Proxy代理后仍无法生效的解决
Nov 13 Javascript
ionic cordova一次上传多张图片(类似input file提交表单)的实现方法
Dec 16 #Javascript
在JS中a标签加入单击事件屏蔽href跳转页面
Dec 16 #Javascript
概述jQuery中的ajax方法
Dec 16 #Javascript
JS数组排序方法实例分析
Dec 16 #Javascript
jquery UI Datepicker时间控件冲突问题解决
Dec 16 #Javascript
详解jQuery简单的表单应用
Dec 16 #Javascript
浅谈JavaScript的自动垃圾收集机制
Dec 15 #Javascript
You might like
探讨PHP中OO之静态关键字以及类常量的详解
2013/06/07 PHP
php缓冲输出实例分析
2015/01/05 PHP
用php代码限制国内IP访问我们网站
2015/09/26 PHP
php将数组存储为文本文件方法汇总
2015/10/28 PHP
PHP使用http_build_query()构造URL字符串的方法
2016/04/02 PHP
thinkphp5.1框架中容器(Container)和门面(Facade)的实现方法分析
2019/08/05 PHP
Javascript实例教程(19) 使用HoTMetal(5)
2006/12/23 Javascript
检测是否已安装 .NET Framework 3.5的js脚本
2009/02/14 Javascript
改善你的jQuery的25个步骤 千倍级效率提升
2010/02/11 Javascript
使用jquery实现select添加实现后台权限添加的效果
2011/05/28 Javascript
JavaScript获取/更改文本框的值的实例代码
2013/08/02 Javascript
JQuery插件iScroll实现下拉刷新,滚动翻页特效
2014/06/22 Javascript
JavaScript对HTML DOM使用EventListener进行操作
2015/10/21 Javascript
jquery实现定时自动轮播特效
2015/12/10 Javascript
12个非常有用的JavaScript技巧
2017/05/17 Javascript
JS实现运动缓冲效果的封装函数示例
2018/02/18 Javascript
bootstrap table合并行数据并居中对齐效果
2018/10/17 Javascript
可能被忽略的一些JavaScript数组方法细节
2019/02/28 Javascript
JavaScript函数的4种调用方法实例分析
2019/03/05 Javascript
Vue 实现CLI 3.0 + momentjs + lodash打包时优化
2019/11/13 Javascript
vue学习笔记之slot插槽基本用法实例分析
2020/02/01 Javascript
Python中使用Beautiful Soup库的超详细教程
2015/04/30 Python
使用Python脚本将文字转换为图片的实例分享
2015/08/29 Python
pygame 精灵的行走及二段跳的实现方法(必看篇)
2017/07/10 Python
Python3自动签到 定时任务 判断节假日的实例
2018/11/13 Python
我们为什么要减少Python中循环的使用
2019/07/10 Python
《商鞅南门立木》教学反思
2014/02/16 职场文书
低碳环保倡议书
2014/04/14 职场文书
创文明城市标语
2014/06/16 职场文书
创先争优个人承诺书
2014/08/30 职场文书
大班下学期个人总结
2015/02/13 职场文书
专项资金申请报告
2015/05/15 职场文书
冰雪公主观后感
2015/06/16 职场文书
如何把新闻人物写得立体、鲜活?
2019/08/14 职场文书
MySQL kill不掉线程的原因
2021/05/07 MySQL
浅谈css清除浮动(clearfix和clear)的用法
2023/05/21 HTML / CSS