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

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

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-05-16 17:52:28
原創
922 人瀏覽過

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
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
將 JS 函數傳遞給 WASM
來自於 1970-01-01 08:00:00
0
0
0
javascript - js匿名函數的其中三個書寫方式
來自於 1970-01-01 08:00:00
0
0
0
javascript - js 函數的一點小問題求解
來自於 1970-01-01 08:00:00
0
0
0
javascript - 原生JS的遞迴函數的時間維度
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板