1. 程式人生 > 程式設計 >Node.js API詳解之 util模組用法例項分析

Node.js API詳解之 util模組用法例項分析

本文例項講述了Node.js API詳解之 util模組用法。分享給大家供大家參考,具體如下:

Node.js API詳解之 util

util 模組主要用於支援 Node.js 內部 API 的需求。提供了大部分實用工具。
通過 const util = require(‘util'); 的方式引用util模組

util.callbackify(original)

說明:

original:傳遞一個 async 函式,或者是一個返回Promise的非同步函式。
callbackify會返回一個方法,執行該方法時傳遞一個回撥函式,回撥函式的第一個引數是err,第二個是非同步函式的返回值。

demo:

const util = require('util');
async function fn() {
 return await Promise.resolve('hello isjs');
}
const callbackFunction = util.callbackify(fn);
callbackFunction((err,ret) => {
 if (err) throw err;
 console.log(ret);
});
//輸出: hello isjs

util.debuglog(section)

說明:

util.debuglog() 方法用於建立一個函式,基於 NODE_DEBUG 環境變數的存在與否有條件地寫入除錯資訊到 stderr。

如果 section 名稱在環境變數的值中,則返回的函式類似於 console.error()。 否則,返回的函式是一個空操作。
section:一個字串,指定要為應用的哪些部分建立 debuglog 函式。

demo:

const util = require('util');
const debuglog = util.debuglog('foo');
debuglog('hello from foo [%d]',123);

util.deprecate(function,string)

說明:

該方法會包裝給定的 function 或類,並標記為廢棄的。

demo:

const util = require('util');
function isBoolean(obj){
 return (obj === true || obj === false);
}
isBoolean = util.deprecate(isBoolean,'isBoolean 方法已被廢棄');
isBoolean(true);
//輸出:(node:9911) DeprecationWarning: isBoolean 方法已被廢棄

util.format(format[,…args])

說明:

util.format() 方法返回一個格式化後的字串,
format:第一個引數是一個字串,包含零個或多個佔位符。
每個佔位符會被對應引數轉換後的值所替換。 支援的佔位符有:
%s:字串
%d:數值(整數或浮點數)
%i:整數
%f:浮點數
%j – JSON
%o – Object(包括不可列舉的屬性方法)
%O – Object(不包括不可列舉屬性)
%% – 單個百分號('%')不消耗引數。

demo:

const util = require('util');
var formatString = util.format('%s %d %i %f %j','hello',1.123,123,2.1,"{'name': 'xiao','age': '18'}");
console.log(formatString);
//e輸出: hello 1.123 123 2.1 "{'name': 'xiao','age': '18'}"
//如果佔位符沒有對應的引數,則佔位符不被替換。
formatString = util.format('%s,%s','hello');
console.log(formatString);
//輸出: hello,%s
//如果傳入的引數比佔位符的數量多,則多出的引數會被強制轉換為字串,
//然後拼接到返回的字串,引數之間用一個空格分隔。
formatString = util.format('%s,'isjs','!');
console.log(formatString);
//輸出: hello,isjs !
//如果第一個引數不是一個字串,則返回一個所有引數用空格分隔並連在一起的字串
formatString = util.format(1,2,3);
console.log(formatString);
//輸出: 1 2 3
//如果只傳入佔位符而不傳入引數,則原樣返回
formatString = util.format('%%,%s');
console.log(formatString);
//輸出: %%,%s

util.inherits(constructor,superConstructor)

說明:

注意,不建議使用 util.inherits()。 請使用 ES6 的 class 和 extends 關鍵詞獲得語言層面的繼承支援。
從一個建構函式中繼承原型方法到另一個。
constructor 的 prototype 會被設定到一個從 superConstructor 建立的新物件上。
superConstructor 可通過 constructor.super_ 屬性訪問

demo:

const util = require('util');
const EventEmitter = require('events');
function MyStream() { 
 EventEmitter.call(this);
}
util.inherits(MyStream,EventEmitter);
MyStream.prototype.write = function(data) {
 this.emit('data',data);
};
const stream = new MyStream();
console.log(stream instanceof EventEmitter); // true
console.log(MyStream.super_ === EventEmitter); // true
stream.on('data',(data) => {
 console.log(`接收的資料:"${data}"`);
});
stream.write('運作良好!'); // 接收的資料:"運作良好!"
//建議使用 ES6 的 class 和 extends:
const EventEmitter = require('events');
class MyStream extends EventEmitter {
 write(data) {
 this.emit('data',data);
 }
}
const stream = new MyStream();
stream.on('data',(data) => {
 console.log(`接收的資料:"${data}"`);
});
stream.write('使用 ES6');

util.inspect(object[,options])

說明:

方法返回 object 的字串表示,主要用於除錯。
object: 任何 JavaScript 原始值或物件
options: 可用於改變格式化字串的某些方面。

demo:

const util = require('util');
const inspectOpt = {
 showHidden: false,//如果為 true,則 object 的不可列舉的符號與屬性也會被包括在格式化後的結果中。
 depth: 2,//指定格式化 object 時遞迴的次數。 預設為 2。 若要無限地遞迴則傳入 null。
 colors: false,//如果為 true,則輸出樣式使用 ANSI 顏色程式碼。 預設為 false。
 customInspect: true,//如果為 false,則 object 上自定義的 inspect(depth,opts) 函式不會被呼叫。 預設為 true
 showProxy: false,//如果為 true,則 Proxy 物件的物件和函式會展示它們的 target 和 handler 物件。 預設為 false
 maxArrayLength: 100,//指定格式化時陣列和 TypedArray 元素能包含的最大數量。 預設為 100。 設為 null 則顯式全部陣列元素。 設為 0 或負數則不顯式陣列元素。
 breakLength: 60//一個物件的鍵被拆分成多行的長度。 設為 Infinity 則格式化一個物件為單行。 預設為 60。
};
console.log(util.inspect(util,inspectOpt));

util.inspect.styles,util.inspect.colors

說明:

可以通過 util.inspect.styles 和 util.inspect.colors 屬性全域性地自定義 util.inspect 的顏色輸出(如果已啟用)。
預定義的顏色程式碼有:white、grey、black、blue、cyan、green、magenta、red 和 yellow。
還有 bold、italic、underline 和 inverse 程式碼。
顏色樣式使用 ANSI 控制碼,可能不是所有終端都支援。

demo:

const util = require('util');
console.log(util.inspect.styles);
// { special: 'cyan',// number: 'yellow',// boolean: 'yellow',// undefined: 'grey',// null: 'bold',// string: 'green',// symbol: 'green',// date: 'magenta',// regexp: 'red' }
console.log(util.inspect.colors);
// { bold: [ 1,22 ],// italic: [ 3,23 ],// underline: [ 4,24 ],// inverse: [ 7,27 ],// white: [ 37,39 ],// grey: [ 90,// black: [ 30,// blue: [ 34,// cyan: [ 36,// green: [ 32,// magenta: [ 35,// red: [ 31,// yellow: [ 33,39 ] }

util.inspect.custom

說明:

util.inspect.custom是一個符號,可被用於宣告自定義的檢視函式:[util.inspect.custom](depth,opts)
自定義 inspect 方法的返回值可以使任何型別的值,它會被 util.inspect() 格式化。

demo:

const util = require('util');
class Box {
 [util.inspect.custom](depth,options) {
 return "myInspect";
 }
}
const box = new Box();
console.log(util.inspect(box));
// 輸出:myInspect
 

util.inspect.defaultOptions

說明:

defaultOptions 值允許對 util.inspect 使用的預設選項進行自定義。
它需被設為一個物件,包含一個或多個有效的 util.inspect() 選項。 也支援直接設定選項的屬性。

demo:

const util = require('util');
util.inspect.defaultOptions = {
 showHidden: true,depth:3
};
util.inspect.defaultOptions.breakLength = 30;
console.log(util.inspect.defaultOptions);
// { showHidden: true,// depth: 3,// colors: false,// customInspect: true,// showProxy: false,// maxArrayLength: 100,// breakLength: 30 }

util.promisify(original)

說明:

讓一個遵循通常的 Node.js error first回撥風格的函式,回撥函式是最後一個引數,返回一個返回值是一個 promise 版本的函式。

demo:

const util = require('util');
const fs = require('fs');
const stat = util.promisify(fs.stat);
stat('.').then((stats) => {
 // Do something with `stats`
}).catch((error) => {
 // Handle the error.
});

util.promisify.custom

說明:

使用util.promisify.custom符號可以自定義promisified功能。

demo:

const util = require('util');
function doSomething(foo,callback) {
 // ...
}
doSomething[util.promisify.custom] = function(foo) {
 return getPromiseSomehow();
};
const promisified = util.promisify(doSomething);
console.log(promisified === doSomething[util.promisify.custom]);
// 輸出: true

類:util.TextEncoder

說明:

該類用來對文字進行編碼

textEncoder.encode([input])

說明:

對input字串進行編碼並返回一個Uint8Array包含編碼位元組的字串

textEncoder.encoding

說明:

TextEncoder例項支援的編碼。總是設定為'utf-8'。

demo:

const encoder = new TextEncoder();
const uint8array = encoder.encode('this is some data');
console.log(encoder.encoding)
//utf-8

類:util.TextDecoder

說明:

該類用來解析編碼後的文字

new TextDecoder([encoding[,options]])

說明:

建立一個TextDecoder例項。
encoding: 編碼方式,預設'utf-8′
options: 選項
fatal: 解碼發生的錯誤將導致 TypeError被丟擲。預設為 false
ignoreBOM: 解碼結果中是否會包含位元組順序標記。預設為false。僅當encoding的值為'utf-8','utf-16be'或'utf-16le'時有效。

textDecoder.decode([input[,options]])

說明:

解碼input並返回一個字串。
input: 待解碼資料
options.stream: 如果需要額外的資料塊,設定為true。預設為false。

textDecoder.encoding

說明:

返回textDecoder例項支援的編碼。

textDecoder.fatal

說明:

返回textDecoder例項的fatal屬性,

textDecoder.ignoreBOM

說明:

返回解碼結果是否包含位元組順序標記

希望本文所述對大家node.js程式設計有所幫助。