標籤:return 局部變數 length 變數 bsp type 參數 傳回值 meta
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<script type="text/javascript">
function box(num1,num2){
return num1+num2; //普通函式宣告方式
}
alert(box(1,2));
var box=function(num1,num2){
return num1+num2; //使用變數初始化函數
}
alert(box(1,2));
var box=new Function(‘num1‘,‘num2‘,‘return num1+num2‘);
alert(box(1,2)); //使用new的建構函式來聲明
//函數可以傳遞函數
//下面的例子很普通,不是作為函數來傳遞的,而是作為函數的傳回值來傳遞的
function box(sum,num){
return sum+num;
}
function sum(num){
return num+10;
}
var result=box(sum(10),10); //sum(10)這裡傳遞的是函數的傳回值,和普通的變數一樣,沒區別
alert(result);//30
//要把函數本身作為參數傳遞,而不是函數的結果
function box(sum,num){
return sum(num);
}
function sum(num){
return num+10;
}
var result=box(sum,10);//這個sum是一個函數,當作參數傳遞到另一個函數裡,而不是函數的傳回值。
alert(return);//20
function box(num){
if(num<=1){
return 1;
}else{
return num*arguments.callee(num-1);//4*3*2*1=24階乘,遞迴
} //使用callee調用自身,實現遞迴
}
alert(box(4));
var color="紅色的"; //這裡color就是全域變數,而這個變數又是window的屬性
var box={
color:"藍色的",
sayColor:function(){
alert(this.color); //這裡的color是box下得屬性,也就是局部變數
//這裡this,我們確定是代表的box對象
}
}
alert(this.color); //紅色的
box.sayColor(); //藍色的
function box(name,age){
return name+age;
}
alert(box.length);
function box(num1,num2){
return num1+num2;
}
方法一: function sum(num1,num2){//apply和call可以冒充另外一個函數
return box.apply(this,[num1,num2]);//this表示window範圍,【】表示傳遞的參數
}
方法二: function sum(num1,num2){
return box.apply(this,arguments);//這個可以當數組傳遞
}
//alert(box(10,10)); //20
alert(sum(10,10)); //20
function box(num1,num2){
return num1+num2;
}
function sum(num1,num2){
return box.call(this,num1,num2);//call只是傳遞參數不同,其他和apply一樣
}
alert(sum(10,10));
var color="紅色的";
var box={
color:‘藍色的‘
}
function sayColor(){
alert(this.color);
}
sayColor(); //全域
//用call是實現對象冒充,冒充box下,冒充window下
sayColor.call(window); //冒充window紅色的
sayColor.call(box); //冒充box,範圍就在box對象裡面,所以color就是藍色的
</script>
</body>
</html>
js函式宣告