node.js(十五)

Node.js 常用工具
util 是一個Node.js 核心模塊,提供常用函數(shù)的集合,用于彌補核心JavaScript 的功能 過于精簡的不足。
util.inherits
util.inherits(constructor, superConstructor)是一個實現(xiàn)對象間原型繼承 的函數(shù)。
JavaScript 的面向?qū)ο筇匦允腔谠偷?,與常見的基于類的不同。JavaScript 沒有 提供對象繼承的語言級別特性,而是通過原型復(fù)制來實現(xiàn)的。
在這里我們只介紹util.inherits 的用法,示例如下:

var util = require('util');
 function Base() { this.name = 'base'; 
this.base = 1991;
 this.sayHello = function() { console.log('Hello ' + this.name); 
};
 }
 Base.prototype.showName = function() { console.log(this.name);};
 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();
 //objSub.sayHello(); 
console.log(objSub); 

我們定義了一個基礎(chǔ)對象Base 和一個繼承自Base 的Sub,Base 有三個在構(gòu)造函數(shù) 內(nèi)定義的屬性和一個原型中定義的函數(shù),通過util.inherits 實現(xiàn)繼承。運行結(jié)果如下:

base 
Hello base 
{ name: 'base', base: 1991, sayHello: [Function] } 
sub
 { name: 'sub' }

注意:Sub 僅僅繼承了Base 在原型中定義的函數(shù),而構(gòu)造函數(shù)內(nèi)部創(chuàng)造的 base 屬 性和 sayHello 函數(shù)都沒有被 Sub 繼承。
同時,在原型中定義的屬性不會被console.log 作 為對象的屬性輸出。如果我們?nèi)サ?objSub.sayHello(); 這行的注釋,將會看到:

node.js:201 throw e;
 // process.nextTick error, or 'error' event on first tick
 ^
 TypeError: Object #<Sub> has no method 'sayHello' 
at Object.<anonymous> (/home/byvoid/utilinherits.js:29:8) 
at Module._compile (module.js:441:26) at Object..js (module.js:459:10) 
at Module.load (module.js:348:31) 
at Function._load (module.js:308:12) 
at Array.0 (module.js:479:10) 
at EventEmitter._tickCallback (node.js:192:40) 

util.inspect
util.inspect(object,[showHidden],[depth],[colors])是一個將任意對象轉(zhuǎn)換 為字符串的方法,通常用于調(diào)試和錯誤輸出。它至少接受一個參數(shù) object,即要轉(zhuǎn)換的對象。
showHidden 是一個可選參數(shù),如果值為 true,將會輸出更多隱藏信息。
depth 表示最大遞歸的層數(shù),如果對象很復(fù)雜,你可以指定層數(shù)以控制輸出信息的多 少。如果不指定depth,默認(rèn)會遞歸2層,指定為 null 表示將不限遞歸層數(shù)完整遍歷對象。 如果color 值為 true,輸出格式將會以ANSI 顏色編碼,通常用于在終端顯示更漂亮 的效果。
特別要指出的是,util.inspect 并不會簡單地直接把對象轉(zhuǎn)換為字符串,即使該對 象定義了toString 方法也不會調(diào)用。

var util = require('util'); 
function Person() { this.name = 'byvoid'; this.toString = function() { return this.name; }; } 
var obj = new Person(); console.log(util.inspect(obj)); 
console.log(util.inspect(obj, true)); 

運行結(jié)果是:

Person { name: 'byvoid', toString: [Function] }
Person { name: 'byvoid', 
toString:
 { [Function] [length]: 0,
 [name]: '',
 [arguments]: null, 
[caller]: null,
 [prototype]: { [constructor]: [Circular] } } 
}

util.isArray(object)

如果給定的參數(shù) "object" 是一個數(shù)組返回true,否則返回false。

var util = require('util');
util.isArray([])
 // true
util.isArray(new Array) 
// true
util.isArray({}) 
// false

util.isRegExp(object)
如果給定的參數(shù) "object" 是一個正則表達(dá)式返回true,否則返回false。

var util = require('util');
util.isRegExp(/some regexp/) 
// true
util.isRegExp(new RegExp('another regexp')) 
// true
util.isRegExp({})
 // false

util.isDate(object)
如果給定的參數(shù) "object" 是一個日期返回true,否則返回false。

var util = require('util');
util.isDate(new Date()) 
// true
util.isDate(Date()) 
// false (without 'new' returns a String)
util.isDate({}) 
// false

util.isError(object)
如果給定的參數(shù) "object" 是一個錯誤對象返回true,否則返回false。

var util = require('util');
util.isError(new Error())
 // true
util.isError(new TypeError()) 
// true
util.isError({ name: 'Error', message: 'an error occurred' }) 
// false

更多詳情可以訪問 http://nodejs.org/api/util.html 了解詳細(xì)內(nèi)容。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Node.js 常用工具 util 是一個Node.js 核心模塊,提供常用函數(shù)的集合,用于彌補核心JavaScr...
    FTOLsXD閱讀 606評論 0 2
  • 內(nèi)容來自《Node.js開發(fā)指南》 核心模塊是 Node.js 的心臟,它由一些精簡而高效的庫組成,為 Node....
    angelwgh閱讀 970評論 0 1
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,533評論 19 139
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,637評論 18 399

友情鏈接更多精彩內(nèi)容