首頁  >  文章  >  web前端  >  javascript學習筆記(七) js函數介紹_基礎知識

javascript學習筆記(七) js函數介紹_基礎知識

WBOY
WBOY原創
2016-05-16 17:52:28840瀏覽

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

複製代碼 程式碼如下:

//階乘
function factorial(num) {
if (num return 1;
} else {
return num*arguments.callee(num-1); //用agreements.callee代替
}
}

var trueFactorial = factorial;
factorial = function {
return 0;
}
alert(trueFactorial(5)); //20
alert(factorial(5)); //0

2.函數的屬性和方法
length屬性,表示函數參數的數量

3. apply()和call()方法
apply()和call()方法的作用是傳遞參數或擴充函數的作用域
複製程式碼 程式碼如下:

//傳遞參數
function sum(>
//傳遞參數
function sum(> ,num2) {
return num1 num2;
}
function callSum(num1,num2) {
return sum.call(this,num1,num2); //第一個參數this,後面列舉所有參數
}
alert(callSum(10,10)); //20

function calSum1(num1,num2) {
return sum.apply(this,arguments); //第一個參數this,第二個參數arguments
}
function calSum2(num1,num2) {
return sum.apply(this,[num1,num2]); //第一個參數this,第二個參數是參數陣列
}
alert(callSum1(10,10)); //20
alert(callSum2(10,10)); //20
複製程式碼
程式碼如下:


//改變函數作用域作用.color = "red";
var o = { color:"blue"};
function sayColor() {
alert(this.color);
}
Colsayor(); //red
sayColor.call(this); //red
sayColor.call(window);//red
sayColor.call(o); //blue
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn