js函式宣告

來源:互聯網
上載者:User

標籤: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函式宣告

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.