<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        Node.js使用console輸出日志文件步驟詳解

        來源:懂視網 責編:小采 時間:2020-11-27 19:48:58
        文檔

        Node.js使用console輸出日志文件步驟詳解

        Node.js使用console輸出日志文件步驟詳解:這次給大家帶來Node.js使用console輸出日志文件步驟詳解,Node.js使用console輸出日志文件的注意事項有哪些,下面就是實戰案例,一起來看一下。我們首先創建如下文件:// index.js let fs = require('fs'); let options
        推薦度:
        導讀Node.js使用console輸出日志文件步驟詳解:這次給大家帶來Node.js使用console輸出日志文件步驟詳解,Node.js使用console輸出日志文件的注意事項有哪些,下面就是實戰案例,一起來看一下。我們首先創建如下文件:// index.js let fs = require('fs'); let options

        這次給大家帶來Node.js使用console輸出日志文件步驟詳解,Node.js使用console輸出日志文件的注意事項有哪些,下面就是實戰案例,一起來看一下。

        我們首先創建如下文件:

        // 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);
        // 創建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}`);
        }

        在上面代碼中,我們其實是創建了一個console.Console類的實例,該類需要指定兩個參數,即標準輸出流和標準錯誤輸出流,正常情況下,實際上是對應了process.stdout和process.stderr,以上的代碼中,我們將這兩個輸出流改為了文件輸出流,并指定為文件追加模式,這樣即可將日志信息輸出到指定的文件中去。運行上面的代碼,會生成stdout.log和stderr.log兩個文件。

        stdout.log文件內容如下:

        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文件內容如下:

        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
        ...

        看上去信息還比較簡單,不像是日志文件的樣子,我們或許得為每條日志添加一個時間才行,下面先為Date對象添加一個format的原型方法:

        // 添加format方法
        Date.prototype.format = function (format) {
         if (!format) {
         format = 'yyyy-MM-dd HH:mm:ss';
         }
         
         // 用0補齊指定位數
         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), // 時
         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);
        // 創建logger
        let logger = new console.Console(stdout, stderr);
        // 添加format方法
        Date.prototype.format = function (format) {
         if (!format) {
         format = 'yyyy-MM-dd HH:mm:ss';
         }
         
         // 用0補齊指定位數
         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), // 時
         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}`);
        }

        重新運行程序,然后查看兩個日志文件的內容。

        stdout.log內容如下:

        [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內容如下:

        [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
        ...

        這樣一個簡單的日志輸出就完成了。

        相信看了本文案例你已經掌握了方法,更多精彩請關注Gxl網其它相關文章!

        推薦閱讀:

        Vue nextTick 機制使用詳解

        vue+jquery+lodash滑動時頂部懸浮固定功能實現詳解

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        Node.js使用console輸出日志文件步驟詳解

        Node.js使用console輸出日志文件步驟詳解:這次給大家帶來Node.js使用console輸出日志文件步驟詳解,Node.js使用console輸出日志文件的注意事項有哪些,下面就是實戰案例,一起來看一下。我們首先創建如下文件:// index.js let fs = require('fs'); let options
        推薦度:
        標簽: 文件 方法 js
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 久久久久久久亚洲Av无码| 亚洲第一网站男人都懂| 久久精品国产亚洲AV无码偷窥| 国产拍拍拍无码视频免费| 三上悠亚亚洲一区高清| 久久久久久国产a免费观看不卡| 亚洲亚洲人成综合网络| baoyu116.永久免费视频| 亚洲动漫精品无码av天堂| 久久这里只精品99re免费| 麻豆亚洲AV永久无码精品久久 | 久久九九久精品国产免费直播| 又粗又大又长又爽免费视频| 一级毛片在播放免费| 亚洲人色婷婷成人网站在线观看| 青青操免费在线观看| 亚洲欧洲另类春色校园小说| 免费做爰猛烈吃奶摸视频在线观看 | 国产成人精品免费视频网页大全| 亚洲国产成人超福利久久精品| 成年人视频免费在线观看| 亚洲综合成人婷婷五月网址| 无码专区一va亚洲v专区在线| 国产精品免费久久久久影院| 色播亚洲视频在线观看| 成年私人影院免费视频网站| 色五月五月丁香亚洲综合网| 国产亚洲精品成人AA片新蒲金| 99热在线精品免费播放6| 国产亚洲玖玖玖在线观看| 亚洲片国产一区一级在线观看| 亚洲免费观看视频| 亚洲国产精品日韩在线观看| 国产精品久久免费视频| 免费在线看黄的网站| 亚洲娇小性色xxxx| 中文字幕亚洲电影| 无码国产精品久久一区免费| 一级毛片正片免费视频手机看 | 亚洲欧美日韩中文字幕一区二区三区 | 久久av免费天堂小草播放|