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 相关文章推荐
JS 添加网页桌面快捷方式的代码详细整理
Dec 27 Javascript
jquery DIV撑大让滚动条滚到最底部代码
Jun 06 Javascript
JQuery记住用户名和密码的具体实现
Apr 04 Javascript
javascript变量声明实例分析
Apr 25 Javascript
仿Angular Bootstrap TimePicker创建分钟数-秒数的输入控件
Jul 01 Javascript
用jQuery向div中添加Html文本内容的简单实现
Jul 13 Javascript
jquery中关于bind()方法的使用技巧分享
Mar 30 jQuery
jQuery日期范围选择器附源码下载
May 23 jQuery
Angular 4 指令快速入门教程
Jun 07 Javascript
浏览器调试动态js脚本的方法(图解)
Jan 19 Javascript
vue-cli构建vue项目的步骤详解
Jan 27 Javascript
Vue.extend 登录注册模态框的实现
Dec 29 Vue.js
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
追求程序速度,而不是编程的速度
2008/04/23 PHP
使用PHP批量生成随机用户名
2008/07/10 PHP
基于jquery的无缝循环新闻列表插件
2011/03/07 Javascript
Javascript Web Slider 焦点图示例源码
2013/10/10 Javascript
JS中表单的使用小结
2014/01/11 Javascript
javascript根据时间生成m位随机数最大13位
2014/10/30 Javascript
BootStrap下jQuery自动完成的样式调整
2016/05/30 Javascript
jQuery实现订单提交页发送短信功能前端处理方法
2016/07/04 Javascript
JavaScript 判断一个对象{}是否为空对象的简单方法
2016/10/09 Javascript
微信js-sdk分享功能接口常用逻辑封装示例
2016/10/13 Javascript
使用Node.js给图片加水印的方法
2016/11/15 Javascript
Three.js基础部分学习
2017/01/08 Javascript
jquery实现表单获取短信验证码代码
2017/03/13 Javascript
浅谈ECMAScript6新特性之let、const
2017/08/02 Javascript
浅谈在Vue-cli里基于axios封装复用请求
2017/11/06 Javascript
angular 数据绑定之[]和{{}}的区别
2018/09/25 Javascript
Vue项目自动转换 px 为 rem的实现方法
2018/10/29 Javascript
JavaScript常见事件对象与操作实例总结
2019/01/05 Javascript
Django实战之用户认证(用户登录与注销)
2018/07/16 Python
Python判断变量名是否合法的方法示例
2019/01/28 Python
Python minidom模块用法示例【DOM写入和解析XML】
2019/03/25 Python
Flask框架中request、请求钩子、上下文用法分析
2019/07/23 Python
Python爬虫设置ip代理过程解析
2020/07/20 Python
Python通过递归函数输出嵌套列表元素
2020/10/15 Python
高山背包:High Sierra
2017/11/23 全球购物
美国亚马逊旗下时尚女装网店:SHOPBOP(支持中文)
2020/10/17 全球购物
第一范式(1NF)、第二范式(2NF)和第三范式(3NF)之间的区别是什么?
2016/04/28 面试题
MySQL面试题目集锦
2016/04/14 面试题
教育专业个人求职信
2013/12/02 职场文书
服务理念口号
2014/06/11 职场文书
国际贸易求职信
2014/07/05 职场文书
学校党的群众路线教育实践活动对照检查材料
2014/09/24 职场文书
母亲节感言
2015/08/03 职场文书
高中语文教学反思范文
2016/02/16 职场文书
gateway与spring-boot-starter-web冲突问题的解决
2021/07/16 Java/Android
Jpa Specification如何实现and和or同时使用查询
2021/11/23 Java/Android