国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Javascript中的方法和匿名方法實(shí)例詳解

2024-05-06 16:22:28
字體:
供稿:網(wǎng)友

這篇文章主要介紹了Javascript中的方法和匿名方法,以實(shí)例形式較為詳細(xì)的分析了javascript中方法及匿名方法的定義與使用技巧,需要的朋友可以參考下

本文實(shí)例講述了Javascript中的方法和匿名方法。分享給大家供大家參考。具體分析如下:

Javascript方法(函數(shù))

聲明函數(shù)

以function開頭,后跟函數(shù)名,與C#、java不同,Javascript不需要聲明返回值類型、參數(shù)類型。沒有返回值就是undefined。

舉個(gè)例子更清楚:

無參數(shù)無返回值的方法:

 

 
  1. function f1(){ 
  2. alert('這是一個(gè)方法'); 
  3. f1();//調(diào)用方法  

無參數(shù)有返回值的方法:

 

 
  1. function f2(){ 
  2. return 100; 
  3. var result=f2();//聲明一個(gè)變量,接收f1()中的返回值 
  4. alert(result);//100  

有參數(shù)有返回值的方法:

 

 
  1. function f3(n1,n2){ 
  2. return n1+n2; 
  3. var result=f3(20,30); 
  4. alert(result);//50 

注意1:

先看例子:

 

 
  1. function f1(){ 
  2. alert('這是一個(gè)方法');  
  3. alert(f1());//彈出”這是一個(gè)方法”后,還會(huì)顯示undefined 

原因:js中,變量沒有賦值,就是undefined;該栗中f1()沒有返回值,那么就是一個(gè)未知的值(undefined),這里未知的變量放入alert(),當(dāng)然彈出的就是undefined

注意2:

 

 
  1. alert(f1);//不寫括號(hào),會(huì)將f1整個(gè)代碼以字符串形式顯示出來: 
  2. function f1(){  
  3. alert('這是一個(gè)方法');  
  4. }  

JavaScript中沒有方法重載

只調(diào)用最新定義的方法:

 

 
  1. function f1(n1,n2){  
  2. alert(n1+n2);  
  3. }  
  4. function f1(n1,n2){  
  5. alert(n1-n2);  
  6. }  
  7. f1(10,2);//8 

結(jié)論:無論在哪里調(diào)用,都只調(diào)用最新定義的方法。

注意:數(shù)字+undefined=undefined

 

 
  1. function f1(n1,n2,n3){  
  2. alert(n1-n2+n3);  
  3. }  
  4. f1(10,2); 
  5. //NaN,因?yàn)闆]有給n3傳值,n3就是undefined, 
  6. //數(shù)字加上undefined還是undefined 

以上結(jié)論:Javascript中沒有方法重載

定義方法時(shí)注意:

自定義函數(shù)名不要和內(nèi)置方法重名:

不要和js內(nèi)置、dom內(nèi)置方法重名,比如selectAll、focus等函數(shù)名不要用。

不要與系統(tǒng)函數(shù)重名。(在單擊事件中調(diào)用自己定義的focus方法,有問題。與系統(tǒng)的focus()方法重名了)

書寫規(guī)則括號(hào)注意:

一般在js中編寫大括號(hào)都是直接跟在后面

 

 
  1. function f1(){  
  2. return 
  3. {  
  4. age:100};  
  5. }  
  6. var s=f1();  
  7. alert(s.age); 
  8. //undefined。s結(jié)果是undefined,undefined.age必然還是undefined 

匿名方法(用的非常多)

為什么推薦用匿名方法?

1、有一個(gè)1.js中有個(gè)方法function aa(){alert{'我挺帥了'}}

2、有一個(gè)2.js中有個(gè)方法function aa(){alert{'我越來越帥了'}}

3、將1.js和2.js依次導(dǎo)入到index.html中,調(diào)用aa();結(jié)果顯示:我越來越帥了。

結(jié)論:2.js中的aa()方法會(huì)覆蓋1.js中的aa()

怎么辦?不再指定方法名,使用匿名方法

先看一個(gè)將匿名方法賦給變量例子:

 

 
  1. var ff=function(n1,n2){  
  2. return n1+n2;  
  3. };  
  4. alert(ff(20,30));//50 

一行寫完匿名方法:

代碼如下:
(function (n1,n2){alert(n1+n2);})(9,9);
 

小案例:1:

 

 
  1. var x=1;  
  2. var y=0;  
  3. var z=0;  
  4. var add=function (n){n=n+1;return n};  
  5. y=add(x);//結(jié)果是2,先調(diào)用上面add  
  6. add=function(n){n=n+3;return n;};  
  7. z=add(x);//結(jié)果是4,調(diào)用上面臨近的這個(gè)add  
  8. alert(y+','+z);//2,4 

小案例2:

 

 
  1. function aa()  
  2. {  
  3. alert("aaa");  
  4. return function(){alert("bbb");};  
  5. }  
  6. alert(aa);//不寫括號(hào),會(huì)將aa方法的整個(gè)代碼顯示出來  
  7. alert(aa());//aaa,function(){alert("bbb");}; aaa就不解釋了,后面那一串是作為aa()的返回值顯示  
  8. alert(aa()());//aaa,bbb,undefined  
  9. //下面分解上面這句進(jìn)行解釋  
  10. var s=aa();//aaa  
  11. alert(s());//s()就是function(){alert("bbb");};首先彈出bbb,其次該方法沒有返回值,故彈出undefined 

希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 日土县| 七台河市| 永定县| 长顺县| 河曲县| 井冈山市| 滨州市| 九江市| 沽源县| 清河县| 甘泉县| 蓬莱市| 通海县| 武汉市| 池州市| 西城区| 阿拉善右旗| 乌兰浩特市| 太保市| 华亭县| 托克逊县| 安国市| 温宿县| 鄂托克旗| 图们市| 哈尔滨市| 绍兴县| 盐边县| 启东市| 西平县| 余江县| 临漳县| 措美县| 修文县| 临武县| 方城县| 公安县| 望都县| 固阳县| 句容市| 平乡县|