本篇文章主要介绍了node.js readline模块与util模块的使用,现在分享给大家,也给大家做个参考。
1. 使用readline模块逐行读取流数据
1.1. 创建interface对象
在readline模块中,通过interface对象的使用来实现逐行读取流数据的处理。因此首先要创建interface对象,在readline模块中,可以通过createinterface方法来创建interface对象.readline.createinterface(options),options为一个对象,属性如下
input: 属性值为一个可用来读取流数据的对象,用于指定读入数据的来源。
output: 属性值为一个可用来写入流数据的对象,用于指定数据的输出目标。
computer: 属性值为一个函数,用于指定tab补全处理。函数的参数值被自动设定为从该行中读入的tab字符之前的数据,该函数应该返回一个由所有用于tab补全时的匹配字符串组成的数组以及从该行中读入的tab字符之前的数据。
terminal: 该属性为一个布尔类型的属性,当需要像一个终端那样实时地将输入数据流进行输出,且需要在输出数据中写入ansi/vt100控制字符串时,需要将该属性值设置为true,默认属性值等于output属性值对象的istty属性值。
// 输入 exit, quit,q这三个任意之一的时候,会退出
const readline = require('readline');
let rl = readline.createinterface({
  input: process.stdin,
  output: process.stdout,
  completer: completer
});
rl.on('line', (line) => {
  if (line === 'exit' || line === 'quit' || line === 'q') {
    rl.close();
  } else {
    console.log('您输入了:', line);
  }
});
rl.on('close', () => {
  console.log('行数据读取操作被终止');
});
function completer(line) {
  const completions = '.help .error .exit .quit .q'.split(' ');
  let hits = completions.filter((c) => {
    return c.indexof(line) === 0;
  });
  return [hits.length ? hits : completions, line]
}
1.2. 使用interface对象逐行读取文件
原fs.js文件的内容
console.log('this is line 1');
console.log('this is line 2');
console.log('this is line 3');
console.log('this is line 4');
console.log('this is line 5');
代码内容
const readline = require('readline');
const fs = require('fs');
let file = fs.createreadstream('./fs.js');
let out = fs.createwritestream('./anotherfs.js');
let index = 1;
out.write('/*line' + index.tostring() + ": */");
let rl = readline.createinterface({
  input: file,
  output: out,
  terminal: true
});
rl.on('line', (line) => {
  if (line === '') {
    rl.close();
  } else {
    index++;
    out.write('/*line' + index.tostring() + ': */');
  }
});
生成的anotherfs.js文件的内容
/*line1: */console.log('this is line 1');
/*line2: */console.log('this is line 2');
/*line3: */console.log('this is line 3');
/*line4: */console.log('this is line 4');
/*line5: */console.log('this is line 5');/*line6: */
2. 使用util模块中提供的一些方法
+format方法
类似于c语言中的printf方法,将第一个参数值作为一个格式化字符串,将其他参数值作为该格式化字符串中所使用的各中参数,返回一个经过格式化处理后的字符串.util.format('您输入了%d个参数,参数值分别为%s,%s,%s',3,'nice','excelent','holy');
格式化字符串中,可以使用的参数指定符号
*`%s`:用于指定字符串参数
*`%d`:用于指定数值参数,包括整数及浮点数
*`%j`:用于指定一个`json`对象
*`%%`:用于指定一个百分号
*如果格式化字符串中使用的参数个数多于format方法中使用的除了`format`参数之外的其他参数,则格式化字符串中多于的参数将不被替换.`console.log(util.format('%s:%s','one'));`
*如果格式化字符串中使用的参数个数少于`format`方法中使用的除了`format`参数之外的其他参数,则根据`format`方法中多于参数值的类型自动将其转换为字符串,中间使用一个空格进行分割.
+inspect(object,[options])返回一个字符串,该字符串包含了对象的信息,在调试应用程序的过程中非常有用.
*`showhidden<boolean>`如果为`true`,则`object`的不可枚举的符号与属性也会被包括在格式化后的结果中.默认为`false.`
*`depth<number>`指定格式化`object`时递归的次数.这对查看大型复杂对象很有用.默认为`2`.若要无限地递归则传入`null`.
*`colors<boolean>`如果为`true`,则输出样式使用`ansi`颜色代码.默认为`false`.颜色可自定义.
*`custominspect<boolean>`如果为`false`,则`object`上自定义的`inspect(depth,opts)`函数不会被调用.默认为`true`.
*`showproxy<boolean>`如果为`true`,则`proxy`对象的对象和函数会展示它们的`target`和`handler`对象.默认为`false`.
*`maxarraylength<number>`指定格式化时数组和`typedarray`元素能包含的最大数量.默认为`100`.设为`null`则显式全部数组元素.设为`0*`或负数则不显式数组元素.
*`breaklength<number>`一个对象的键被拆分成多行的长度.设为`infinity`则格式化一个对象为单行.默认为`60`.
+自定义util.inspect颜色
可以通过util.inspect.styles和util.inspect.colors属性全局地自定义util.inspect的颜色输出(如果已启用)
const util = require('util');
console.log(util.format('您输入了%d个参数,参数值分别为%s,%s,%s', 3, 'nice', 'excelent', 'holy'));
//您输入了3个参数,参数值分别为nice,excelent,holy
console.log(util.format('一个json对象%j', {'name': 'jack', 'age': 25}));
// 一个json对象{"name":"jack","age":25}
console.log(util.format('一个百分号%'));// 一个百分号%
console.log(util.format('%s:%s', 'one'));// one:%s
console.log(util.format('%s', 'one', 'two', 'three', {'name': 'jack'}));
function test(one, two) {
  return one + two;
}
let parent = new object();
parent.name = 'parent';
parent.func = test;
let child1 = new object();
child1.name = 'child1';
parent.child1 = child1;
let child2 = new object();
child2.name = 'child2';
child1.child = child2;
let child3 = new object();
child3.name = 'child3';
child2.child = child3;
child2.inspect = function (depth) {
  return util.inspect(this, {depth: depth - 2, custominspect: false})
};
console.log(util.inspect(parent, {custominspect: true, depth: 4}));
/**
 * { name: 'parent',
 *  func: [function: test],
 *  child1:
 *  { name: 'child1',
 *   child: { name: 'child2', child: [object], inspect: [function] } } }
 * **/
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
vue轮播图插件vue-concise-slider的使用
vue页面离开后执行函数的实例
解决vue页面刷新或者后退参数丢失的问题
以上就是在node.js中如何使用readline模块与util模块的详细内容。
   
 
   