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

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                # ECMAScript Function 對象(類) **ECMAScript 的函數實際上是功能完整的對象。** ## Function 對象(類) ECMAScript 最令人感興趣的可能莫過于函數實際上是功能完整的對象。 Function 類可以表示開發者定義的任何函數。 用 Function 類直接創建函數的語法如下: ``` var function_name = new function(_arg1_, _arg2_, ..., _argN_, _function_body_) ``` 在上面的形式中,每個 _arg_ 都是一個參數,最后一個參數是函數主體(要執行的代碼)。這些參數必須是字符串。 記得下面這個函數嗎? ``` function sayHi(sName, sMessage) { alert("Hello " + sName + sMessage); } ``` 還可以這樣定義它: ``` var sayHi = new Function("sName", "sMessage", "alert(\"Hello \" + sName + sMessage);"); ``` 雖然由于字符串的關系,這種形式寫起來有些困難,但有助于理解函數只不過是一種引用類型,它們的行為與用 Function 類明確創建的函數行為是相同的。 請看下面這個例子: ``` function doAdd(iNum) { alert(iNum + 20); } function doAdd(iNum) { alert(iNum + 10); } doAdd(10); //輸出 "20" ``` 如你所知,第二個函數重載了第一個函數,使 doAdd(10) 輸出了 "20",而不是 "30"。 如果以下面的形式重寫該代碼塊,這個概念就清楚了: ``` var doAdd = new Function("iNum", "alert(iNum + 20)"); var doAdd = new Function("iNum", "alert(iNum + 10)"); doAdd(10); ``` 請觀察這段代碼,很顯然,doAdd 的值被改成了指向不同對象的指針。函數名只是指向函數對象的引用值,行為就像其他對象一樣。甚至可以使兩個變量指向同一個函數: ``` var doAdd = new Function("iNum", "alert(iNum + 10)"); var alsodoAdd = doAdd; doAdd(10); //輸出 "20" alsodoAdd(10); //輸出 "20" ``` 在這里,變量 doAdd 被定義為函數,然后 alsodoAdd 被聲明為指向同一個函數的指針。用這兩個變量都可以執行該函數的代碼,并輸出相同的結果 - "20"。因此,如果函數名只是指向函數的變量,那么可以把函數作為參數傳遞給另一個函數嗎?回答是肯定的! ``` function callAnotherFunc(fnFunction, vArgument) { fnFunction(vArgument); } var doAdd = new Function("iNum", "alert(iNum + 10)"); callAnotherFunc(doAdd, 10); //輸出 "20" ``` 在上面的例子中,callAnotherFunc() 有兩個參數 - 要調用的函數和傳遞給該函數的參數。這段代碼把 doAdd() 傳遞給 callAnotherFunc() 函數,參數是 10,輸出 "20"。 注意:盡管可以使用 Function 構造函數創建函數,但最好不要使用它,因為用它定義函數比用傳統方式要慢得多。不過,所有函數都應看作 Function 類的實例。 ## Function 對象的 length 屬性 如前所述,函數屬于引用類型,所以它們也有屬性和方法。 ECMAScript 定義的屬性 length 聲明了函數期望的參數個數。例如: ``` function doAdd(iNum) { alert(iNum + 10); } function sayHi() { alert("Hi"); } alert(doAdd.length); //輸出 "1" alert(sayHi.length); //輸出 "0" ``` 函數 doAdd() 定義了一個參數,因此它的 length 是 1;sayHi() 沒有定義參數,所以 length 是 0。 記住,無論定義了幾個參數,ECMAScript 可以接受任意多個參數(最多 25 個),這一點在《函數概述》這一章中講解過。屬性 length 只是為查看默認情況下預期的參數個數提供了一種簡便方式。 ## Function 對象的方法 Function 對象也有與所有對象共享的 valueOf() 方法和 toString() 方法。這兩個方法返回的都是函數的源代碼,在調試時尤其有用。例如: ``` function doAdd(iNum) { alert(iNum + 10); } document.write(doAdd.toString()); ``` 上面這段代碼輸出了 doAdd() 函數的文本。!
                  <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>

                              哎呀哎呀视频在线观看