這篇文章主要介紹console打印日志信息的方法,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

創(chuàng)新互聯(lián)建站成立于2013年,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢想脫穎而出為使命,1280元尖扎做網(wǎng)站,已為上家服務(wù),為尖扎各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:13518219792
我們首先創(chuàng)建如下文件:
// index.js
let fs = require('fs');
let options = {
flags: 'a', // append模式
encoding: 'utf8', // utf8編碼
};
let stdout = fs.createWriteStream('./stdout.log', options);
let stderr = fs.createWriteStream('./stderr.log', options);
// 創(chuàng)建logger
let logger = new console.Console(stdout, stderr);
for (let i = 0; i < 100; i++) {
logger.log(`log message ${i}`);
logger.error(`err message ${i}`);
}在上面代碼中,我們其實(shí)是創(chuàng)建了一個(gè)console.Console類的實(shí)例,該類需要指定兩個(gè)參數(shù),即標(biāo)準(zhǔn)輸出流和標(biāo)準(zhǔn)錯(cuò)誤輸出流,正常情況下,實(shí)際上是對應(yīng)了process.stdout和process.stderr,以上的代碼中,我們將這兩個(gè)輸出流改為了文件輸出流,并指定為文件追加模式,這樣即可將日志信息輸出到指定的文件中去。運(yùn)行上面的代碼,會生成stdout.log和stderr.log兩個(gè)文件。
stdout.log文件內(nèi)容如下:
log message 0 log message 1 log message 2 log message 3 log message 4 log message 5 log message 6 log message 7 log message 8 log message 9 log message 10 ...
stderr.log文件內(nèi)容如下:
err message 0 err message 1 err message 2 err message 3 err message 4 err message 5 err message 6 err message 7 err message 8 err message 9 err message 10 ...
看上去信息還比較簡單,不像是日志文件的樣子,我們或許得為每條日志添加一個(gè)時(shí)間才行,下面先為Date對象添加一個(gè)format的原型方法:
// 添加format方法
Date.prototype.format = function (format) {
if (!format) {
format = 'yyyy-MM-dd HH:mm:ss';
}
// 用0補(bǔ)齊指定位數(shù)
let padNum = function (value, digits) {
return Array(digits - value.toString().length + 1).join('0') + value;
};
// 指定格式字符
let cfg = {
yyyy: this.getFullYear(), // 年
MM: padNum(this.getMonth() + 1, 2), // 月
dd: padNum(this.getDate(), 2), // 日
HH: padNum(this.getHours(), 2), // 時(shí)
mm: padNum(this.getMinutes(), 2), // 分
ss: padNum(this.getSeconds(), 2), // 秒
fff: padNum(this.getMilliseconds(), 3), // 毫秒
};
return format.replace(/([a-z]|[A-Z])(\1)*/ig, function (m) {
return cfg[m];
});
}然后再改寫前面的主文件:
// index.js
let fs = require('fs');
let options = {
flags: 'a', // append模式
encoding: 'utf8', // utf8編碼
};
let stdout = fs.createWriteStream('./stdout.log', options);
let stderr = fs.createWriteStream('./stderr.log', options);
// 創(chuàng)建logger
let logger = new console.Console(stdout, stderr);
// 添加format方法
Date.prototype.format = function (format) {
if (!format) {
format = 'yyyy-MM-dd HH:mm:ss';
}
// 用0補(bǔ)齊指定位數(shù)
let padNum = function (value, digits) {
return Array(digits - value.toString().length + 1).join('0') + value;
};
// 指定格式字符
let cfg = {
yyyy: this.getFullYear(), // 年
MM: padNum(this.getMonth() + 1, 2), // 月
dd: padNum(this.getDate(), 2), // 日
HH: padNum(this.getHours(), 2), // 時(shí)
mm: padNum(this.getMinutes(), 2), // 分
ss: padNum(this.getSeconds(), 2), // 秒
fff: padNum(this.getMilliseconds(), 3), // 毫秒
};
return format.replace(/([a-z]|[A-Z])(\1)*/ig, function (m) {
return cfg[m];
});
}
for (let i = 0; i < 100; i++) {
let time = new Date().format('yyyy-MM-dd HH:mm:ss.fff');
logger.log(`[${time}] - log message ${i}`);
logger.error(`[${time}] - err message ${i}`);
}重新運(yùn)行程序,然后查看兩個(gè)日志文件的內(nèi)容。
stdout.log內(nèi)容如下:
[2018-04-27 07:30:54.309] - log message 0 [2018-04-27 07:30:54.312] - log message 1 [2018-04-27 07:30:54.312] - log message 2 [2018-04-27 07:30:54.312] - log message 3 [2018-04-27 07:30:54.312] - log message 4 [2018-04-27 07:30:54.312] - log message 5 [2018-04-27 07:30:54.312] - log message 6 [2018-04-27 07:30:54.312] - log message 7 [2018-04-27 07:30:54.312] - log message 8 [2018-04-27 07:30:54.312] - log message 9 [2018-04-27 07:30:54.312] - log message 10 ...
stderr.log內(nèi)容如下:
[2018-04-27 07:30:54.309] - err message 0 [2018-04-27 07:30:54.312] - err message 1 [2018-04-27 07:30:54.312] - err message 2 [2018-04-27 07:30:54.312] - err message 3 [2018-04-27 07:30:54.312] - err message 4 [2018-04-27 07:30:54.312] - err message 5 [2018-04-27 07:30:54.312] - err message 6 [2018-04-27 07:30:54.312] - err message 7 [2018-04-27 07:30:54.312] - err message 8 [2018-04-27 07:30:54.312] - err message 9 [2018-04-27 07:30:54.312] - err message 10 ...
以上是“console打印日志信息的方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
網(wǎng)站標(biāo)題:console打印日志信息的方法
文章網(wǎng)址:http://www.chinadenli.net/article14/geeide.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計(jì)、響應(yīng)式網(wǎng)站、自適應(yīng)網(wǎng)站、營銷型網(wǎng)站建設(shè)、手機(jī)網(wǎng)站建設(shè)、企業(yè)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)