javascript學習筆記(七)函數

1.函數內部屬性 arguments
arguments用來保存函數的參數,arguments.callee指向擁有arguments對象的函數

 1 //階乘
 2 function factorial(num) {
 3     if (num <= 1) {
 4         return 1;
 5     } else {
 6         return num*arguments.callee(num-1);    //用agreements.callee代替
 7     }
 8 }
 9
10 var trueFactorial = factorial;
11 factorial = function {
12     return 0;
13 }
14 alert(trueFactorial(5));     //20
15 alert(factorial(5));        //0
2.函數的屬性和方法
length屬性,表示函數參數的個數

3. apply()和call()方法
apply()和call()方法的作用是傳遞參數或擴充函數的作用域

 1 //傳遞參數
 2 function sum(num1,num2) {
 3     return num1+num2;
 4 }
 5 function callSum(num1,num2) {
 6     return sum.call(this,num1,num2);        //第一個參數this,後面列舉所有參數
 7 }
 8 alert(callSum(10,10));        //20
 9
10 function calSum1(num1,num2) {
11     return sum.apply(this,arguments);        //第一個參數this,第二個參數arguments
12 }
13 function calSum2(num1,num2) {
14     return sum.apply(this,[num1,num2]);        //第一個參數this,第二個參數是參數數組
15 }
16 alert(callSum1(10,10));        //20
17 alert(callSum2(10,10));        //20

 1 //改變函數作用域
 2 window.color = "red";
 3 var o = { color:"blue"};
 4 function sayColor() {
 5     alert(this.color);
 6 }
 7 sayColor();        //red
 8 sayColor.call(this);        //red
 9 sayColor.call(window);//red
10 sayColor.call(o);        //blue

 

 

摘自 晴天漫步

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *