Node.js常用工具
23539 ワード
タイトルなし
util.inheits
util.inhersはオブジェクト間の原型継承を実現する関数です.
JavaScriptのオブジェクト指向特性は、プロトタイプに基づいており、一般的なベースクラスとは異なります.JavaScriptは対象継承の言語レベル特性を提供しておらず、プロトタイプコピーによって実現されます.
ここではutil.inheitsの使い方だけを紹介します.例は以下の通りです.
また、プロトタイプで定義されている属性は、consolone.logを対象とした属性出力にはなりません.もし私たちがobjSub.sayHelloを外したら.この行のコメントは、次のようになります.
注意:Subはベースのプロトタイプで定義された関数だけを継承していますが、構造関数内部で作成されたベース属性とsayHello関数はSubに継承されていません.
また、プロトタイプで定義されている属性は、consolone.logを対象とした属性出力にはなりません.もし私たちがobjSub.sayHelloを外したら.この行のコメントは、次のようになります.
util.inspectは、任意のオブジェクトを文字列に変換する方法で、通常はデバッグやエラー出力に用いられます.これは少なくとも一つのパラメータobjectを受け入れます.すなわち変換する対象です.
showHddenはオプションのパラメータです.もし値がtrueであれば、より多くの隠し情報を出力します.
depthは最大再帰層数を表しています.オブジェクトが複雑であれば、出力情報の数をコントロールするために階数を指定できます.depthを指定しない場合、デフォルトは2階に戻り、nullとして指定された表現は再帰層数に制限されずにオブジェクトを巡回します.カラー値がtrueであれば、出力フォーマットはANSI色で符号化され、端末でより綺麗な効果を表示するために一般的に使用される.
特に、util.inspectは、オブジェクトを文字列に直接変換することは簡単ではなく、オブジェクトがtoStringメソッドを定義しても呼び出されない.
与えられたパラメータが「object」である場合、配列はtrueに戻ります.そうでなければfalseに戻ります.
util.inheits
util.inhersはオブジェクト間の原型継承を実現する関数です.
JavaScriptのオブジェクト指向特性は、プロトタイプに基づいており、一般的なベースクラスとは異なります.JavaScriptは対象継承の言語レベル特性を提供しておらず、プロトタイプコピーによって実現されます.
ここではutil.inheitsの使い方だけを紹介します.例は以下の通りです.
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);
ベースオブジェクトベースベースとベースから継承されたSubを定義しました.ベースは3つの構造関数で定義された属性とプロトタイプで定義された関数を持っています.運転結果は以下の通りです.
base
Hello base
{ name: 'base', base: 1991, sayHello: [Function] }
sub
{ name: 'sub' }
注意:Subはベースのプロトタイプで定義された関数だけを継承していますが、構造関数内部で作成されたベース属性とsayHello関数はSubに継承されていません.また、プロトタイプで定義されている属性は、consolone.logを対象とした属性出力にはなりません.もし私たちがobjSub.sayHelloを外したら.この行のコメントは、次のようになります.
注意:Subはベースのプロトタイプで定義された関数だけを継承していますが、構造関数内部で作成されたベース属性とsayHello関数はSubに継承されていません.
また、プロトタイプで定義されている属性は、consolone.logを対象とした属性出力にはなりません.もし私たちが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.inspectutil.inspectは、任意のオブジェクトを文字列に変換する方法で、通常はデバッグやエラー出力に用いられます.これは少なくとも一つのパラメータobjectを受け入れます.すなわち変換する対象です.
showHddenはオプションのパラメータです.もし値がtrueであれば、より多くの隠し情報を出力します.
depthは最大再帰層数を表しています.オブジェクトが複雑であれば、出力情報の数をコントロールするために階数を指定できます.depthを指定しない場合、デフォルトは2階に戻り、nullとして指定された表現は再帰層数に制限されずにオブジェクトを巡回します.カラー値がtrueであれば、出力フォーマットはANSI色で符号化され、端末でより綺麗な効果を表示するために一般的に使用される.
特に、util.inspectは、オブジェクトを文字列に直接変換することは簡単ではなく、オブジェクトがtoStringメソッドを定義しても呼び出されない.
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));
運転結果は:
{ name: 'byvoid', toString: [Function] }{ toString:{ [Function][prototype]: { [constructor]: [Circular] },[caller]: null,[length]: 0,[name]: '',[arguments]: null },
name: 'byvoid' }
util.isAray(object)与えられたパラメータが「object」である場合、配列はtrueに戻ります.そうでなければfalseに戻ります.
var util = require('util');
util.isArray([])// true
util.isArray(new Array)// true
util.isArray({})// false
util.isRegExp(object)
“object” true, false。
var util = require('util');
util.isRegExp(/some regexp/)// true
util.isRegExp(new RegExp('another regexp'))// true
util.isRegExp({})// false
util.isDate(object)
“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)
“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