<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??碼云GVP開源項目 12k star Uniapp+ElementUI 功能強大 支持多語言、二開方便! 廣告
                # Node.js 常用工具 util util 是一個Node.js 核心模塊,提供常用函數的集合,用于彌補核心JavaScript 的功能 過于精簡的不足。 ## util.inherits util.inherits(constructor, superConstructor)是一個實現對象間原型繼承 的函數。 JavaScript 的面向對象特性是基于原型的,與常見的基于類的不同。JavaScript 沒有 提供對象繼承的語言級別特性,而是通過原型復制來實現的。 在這里我們只介紹util.inherits 的用法,示例如下: ``` varutil = require('util'); functionBase() { this.name = 'base'; this.base = 1991; this.sayHello = function() { console.log('Hello ' + this.name); }; } Base.prototype.showName = function() { console.log(this.name); }; functionSub() { this.name = 'sub'; } util.inherits(Sub, Base); varobjBase = newBase(); objBase.showName(); objBase.sayHello(); console.log(objBase); varobjSub = newSub(); objSub.showName(); //objSub.sayHello(); console.log(objSub); ``` 我們定義了一個基礎對象Base 和一個繼承自Base 的Sub,Base 有三個在構造函數 內定義的屬性和一個原型中定義的函數,通過util.inherits 實現繼承。運行結果如下: ``` base Hello base { name: 'base', base: 1991, sayHello: [Function] } sub { name: 'sub' } ``` **注意:**Sub 僅僅繼承了Base 在原型中定義的函數,而構造函數內部創造的 base 屬 性和 sayHello 函數都沒有被 Sub 繼承。 同時,在原型中定義的屬性不會被console.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.inspect util.inspect(object,[showHidden],[depth],[colors])是一個將任意對象轉換 為字符串的方法,通常用于調試和錯誤輸出。它至少接受一個參數 object,即要轉換的對象。 showHidden 是一個可選參數,如果值為 true,將會輸出更多隱藏信息。 depth 表示最大遞歸的層數,如果對象很復雜,你可以指定層數以控制輸出信息的多 少。如果不指定depth,默認會遞歸2層,指定為 null 表示將不限遞歸層數完整遍歷對象。 如果color 值為 true,輸出格式將會以ANSI 顏色編碼,通常用于在終端顯示更漂亮 的效果。 特別要指出的是,util.inspect 并不會簡單地直接把對象轉換為字符串,即使該對 象定義了toString 方法也不會調用。 ``` varutil = require('util'); functionPerson() { this.name = 'byvoid'; this.toString = function() { return this.name; }; } varobj = newPerson(); 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.isArray(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 ``` 更多詳情可以訪問 [http://nodejs.org/api/util.html](//nodejs.org/api/util.html) 了解詳細內容。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看