Node.js 经常使用工具 util

util 是一个 Node.js 核心模块,提供经常使用函数的集合,用于弥补核心 Javascript 功能过于精简的不足。
ide


util.inherits(constructor, superConstructor)函数

实现对象间原型继承的函数,第一个构造函数 将从 第二个构造函数那里继承原型的方法ui


JavaScript 的面向对象特性是基于原型的,与常见的基于类的不一样。JavaScript 没有 提供对象继承的语言级别特性,而是经过原型复制来实现this


示例代码以下:
编码

var util = require('util');

//基础对象
function Base(){
    this.name = 'base';
    this.base = '1990';

    this.sayHello = function(){
        console.log('Hello '+this.name);
    }
};

Base.prototype.showName = function(){
    console.log(this.name);
};

//继承自 Base 的对象
function Sub(){
    this.name = 'sub';
}

util.inherits(Sub, Base);

var objBase = new Base();
objBase.showName();
objBase.sayHello();
console.log(objBase);

var objSub = new Sub();
objSub.showName();
console.log(objSub);


咱们定义了一个基础对象 Base 和一个继承自 Base 的 Sub,Base 有三个在构造函数内定义的属性和一个原型中定义的函数,经过 util.inherits 实现继承。结果以下:spa

wKioL1h16b2wjkqZAAAlbaPiTAo783.png


注意,Sub 仅仅继承了 Base 在原型中定义的函数,而构造函数内部创造的 base 属性和 sayHello 函数都没有被 Sub 继承。同时,在原型中定义的属性不会被 console.log 做为对象的属性输出。prototype


尝试打印输出 objSub.sayHello() 这个方法,输出的结果是:调试

wKioL1h16sfiVn4CAACwgju0zUY918.png



util.inspect(object,[showHidden],[depth],[colors]code

是一个将任意对象转换成字符串的方法,一般用于调试和错误输出。orm


util.inspect 接受至少一个参数 object,即要转换的对象。


其它可选参数以下:


showHidden <boolean> 是一个可选参数,若是值为 true,将会输出更多隐藏信息


depth <number>  表示最大递归的层数,若是对象很复杂,你能够指定层数以控制输出信息的多少。若是不指定 depth,默认会递归 2 层;指定为 null,表示不限制递归层数,完整遍历对象


colors <boolean> 若是值为 true,输出格式将会以 ANSI 颜色编码,一般用于在终端显示更漂亮的效果


特别要指出的是,util.inspect 并不会简单地直接把对象转换为字符串,即便该对 象定义了 toString 方法也不会调用


示例代码以下:

var util = require('util');

function Person(){
    this.name = 'Roger';

    this.toString = function(){
        return this.name;
    }
}

var obj = new Person();
console.log(util.inspect(obj));
console.log(util.inspect(obj, true));


运行结果:

wKioL1h175qAEq-gAAAyNT_RZpk861.png