国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

有空看下這篇關(guān)于JS的文章

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 20:26:04
文檔

有空看下這篇關(guān)于JS的文章

有空看下這篇關(guān)于JS的文章:函數(shù)是進(jìn)行模塊化程序設(shè)計(jì)的基礎(chǔ),編寫復(fù)雜的Ajax應(yīng)用程序,必須對函數(shù)有更深入的了解。 javascript中的函數(shù)不同于其他的語言,每個函數(shù)都是作為一個對象被維護(hù)和運(yùn)行的。通過函數(shù)對象的性質(zhì),可以很方便的將一個函數(shù)賦值給一個變量或者將函數(shù)作為參數(shù)傳遞。
推薦度:
導(dǎo)讀有空看下這篇關(guān)于JS的文章:函數(shù)是進(jìn)行模塊化程序設(shè)計(jì)的基礎(chǔ),編寫復(fù)雜的Ajax應(yīng)用程序,必須對函數(shù)有更深入的了解。 javascript中的函數(shù)不同于其他的語言,每個函數(shù)都是作為一個對象被維護(hù)和運(yùn)行的。通過函數(shù)對象的性質(zhì),可以很方便的將一個函數(shù)賦值給一個變量或者將函數(shù)作為參數(shù)傳遞。

函數(shù)是進(jìn)行模塊化程序設(shè)計(jì)的基礎(chǔ),編寫復(fù)雜的Ajax應(yīng)用程序,必須對函數(shù)有更深入的了解。

  javascript中的函數(shù)不同于其他的語言,每個函數(shù)都是作為一個對象被維護(hù)和運(yùn)行的。通過函數(shù)對象的性質(zhì),可以很方便的將一個函數(shù)賦值給一個變量或者將函數(shù)作為參數(shù)傳遞。在繼續(xù)講述之前,先看一下函數(shù)的使用語法:

以下是引用片段:

function func1(…){…}
var func2=function(…){…};
var func3=function func4(…){…};
var func5=new Function();

  這些都是聲明函數(shù)的正確語法。它們和其他語言中常見的函數(shù)或之前介紹的函數(shù)定義方式有著很大的區(qū)別。那么在JavaScript中為什么能這么寫?它所遵循的語法是什么呢?下面將介紹這些內(nèi)容。

  認(rèn)識函數(shù)對象(Function Object)

  可以用function關(guān)鍵字定義一個函數(shù),并為每個函數(shù)指定一個函數(shù)名,通過函數(shù)名來進(jìn)行調(diào)用。在JavaScript解釋執(zhí)行時,函數(shù)都是被維護(hù)為一個對象,這就是要介紹的函數(shù)對象(Function Object)。

  函數(shù)對象與其他用戶所定義的對象有著本質(zhì)的區(qū)別,這一類對象被稱之為內(nèi)部對象,例如日期對象(Date)、數(shù)組對象(Array)、字符串對象(String)都屬于內(nèi)部對象。這些內(nèi)置對象的構(gòu)造器是由JavaScript本身所定義的:通過執(zhí)行new Array()這樣的語句返回一個對象,JavaScript內(nèi)部有一套機(jī)制來初始化返回的對象,而不是由用戶來指定對象的構(gòu)造方式。

  在JavaScript中,函數(shù)對象對應(yīng)的類型是Function,正如數(shù)組對象對應(yīng)的類型是Array,日期對象對應(yīng)的類型是Date一樣,可以通過new Function()來創(chuàng)建一個函數(shù)對象,也可以通過function關(guān)鍵字來創(chuàng)建一個對象。為了便于理解,我們比較函數(shù)對象的創(chuàng)建和數(shù)組對象的創(chuàng)建。先看數(shù)組對象:下面兩行代碼都是創(chuàng)建一個數(shù)組對象myArray:

以下是引用片段:

var myArray=[];
//等價于
var myArray=new Array();

同樣,下面的兩段代碼也都是創(chuàng)建一個函數(shù)myFunction:

function myFunction(a,b){
return a+b;
}
//等價于
var myFunction=new Function("a","b","return a+b");

  通過和構(gòu)造數(shù)組對象語句的比較,可以清楚的看到函數(shù)對象本質(zhì),前面介紹的函數(shù)聲明是上述代碼的第一種方式,而在解釋器內(nèi)部,當(dāng)遇到這種語法時,就會自動構(gòu)造一個Function對象,將函數(shù)作為一個內(nèi)部的對象來存儲和運(yùn)行。從這里也可以看到,一個函數(shù)對象名稱(函數(shù)變量)和一個普通變量名稱具有同樣的規(guī)范,都可以通過變量名來引用這個變量,但是函數(shù)變量名后面可以跟上括號和參數(shù)列表來進(jìn)行函數(shù)調(diào)用。

  用new Function()的形式來創(chuàng)建一個函數(shù)不常見,因?yàn)橐粋€函數(shù)體通常會有多條語句,如果將它們以一個字符串的形式作為參數(shù)傳遞,代碼的可讀性差。下面介紹一下其使用語法:

以下是引用片段:

var funcName=new Function(p1,p2,...,pn,body);

參數(shù)的類型都是字符串,p1到pn表示所創(chuàng)建函數(shù)的參數(shù)名稱列表,body表示所創(chuàng)建函數(shù)的函數(shù)體語句,funcName就是所創(chuàng)建函數(shù)的名稱。可以不指定任何參數(shù)創(chuàng)建一個空函數(shù),不指定funcName創(chuàng)建一個無名函數(shù),當(dāng)然那樣的函數(shù)沒有任何意義。

  需要注意的是,p1到pn是參數(shù)名稱的列表,即p1不僅能代表一個參數(shù),它也可以是一個逗號隔開的參數(shù)列表,例如下面的定義是等價的:

以下是引用片段:

new Function("a", "b", "c", "return a+b+c")
new Function("a, b, c", "return a+b+c")
new Function("a,b", "c", "return a+b+c")

  JavaScript引入Function類型并提供new Function()這樣的語法是因?yàn)楹瘮?shù)對象添加屬性和方法就必須借助于Function這個類型。

  函數(shù)的本質(zhì)是一個內(nèi)部對象,由JavaScript解釋器決定其運(yùn)行方式。通過上述代碼創(chuàng)建的函數(shù),在程序中可以使用函數(shù)名進(jìn)行調(diào)用。本節(jié)開頭列出的函數(shù)定義問題也得到了解釋。注意可直接在函數(shù)聲明后面加上括號就表示創(chuàng)建完成后立即進(jìn)行函數(shù)調(diào)用,例如:

以下是引用片段:

var i=function (a,b){
return a+b;
}(1,2);
alert(i);

  這段代碼會顯示變量i的值等于3。i是表示返回的值,而不是創(chuàng)建的函數(shù),因?yàn)槔ㄌ枴?”比等號“=”有更高的優(yōu)先級。這樣的代碼可能并不常用,但當(dāng)用戶想在很長的代碼段中進(jìn)行模塊化設(shè)計(jì)或者想避免命名沖突,這是一個不錯的解決辦法。

  需要注意的是,盡管下面兩種創(chuàng)建函數(shù)的方法是等價的:

以下是引用片段:

function funcName(){
//函數(shù)體
}
//等價于
var funcName=function(){
//函數(shù)體
}

  但前面一種方式創(chuàng)建的是有名函數(shù),而后面是創(chuàng)建了一個無名函數(shù),只是讓一個變量指向了這個無名函數(shù)。在使用上僅有一點(diǎn)區(qū)別,就是:對于有名函數(shù),它可以出現(xiàn)在調(diào)用之后再定義;而對于無名函數(shù),它必須是在調(diào)用之前就已經(jīng)定義。例如:

以下是引用片段:

<script language="JavaScript" type="text/javascript">
<!--
func();
var func=function(){
alert(1)
}
//-->
</script>

  這段語句將產(chǎn)生func未定義的錯誤,而:

以下是引用片段:

<script language="JavaScript" type="text/javascript">
<!--
func();
function func(){
alert(1)
}
//-->
</script>

  則能夠正確執(zhí)行,下面的語句也能正確執(zhí)行:

以下是引用片段:

<script language="JavaScript" type="text/javascript">
<!--
func();
var someFunc=function func(){
alert(1)
}
//-->
</script>

  由此可見,盡管JavaScript是一門解釋型的語言,但它會在函數(shù)調(diào)用時,檢查整個代碼中是否存在相應(yīng)的函數(shù)定義,這個函數(shù)名只有是通過function funcName()形式定義的才會有效,而不能是匿名函數(shù)。

  函數(shù)對象和其他內(nèi)部對象的關(guān)系

  除了函數(shù)對象,還有很多內(nèi)部對象,比如:Object、Array、Date、RegExp、Math、Error。這些名稱實(shí)際上表示一個類型,可以通過new操作符返回一個對象。然而函數(shù)對象和其他對象不同,當(dāng)用typeof得到一個函數(shù)對象的類型時,它仍然會返回字符串“function”,而typeof一個數(shù)組對象或其他的對象時,它會返回字符串“object”。下面的代碼示例了typeof不同類型的情況:

以下是引用片段:

alert(typeof(Function)));
alert(typeof(new Function()));
alert(typeof(Array));
alert(typeof(Object));
alert(typeof(new Array()));
alert(typeof(new Date()));
alert(typeof(new Object()));

  運(yùn)行這段代碼可以發(fā)現(xiàn):前面4條語句都會顯示“function”,而后面3條語句則顯示“object”,可見new一個function實(shí)際上是返回一個函數(shù)。這與其他的對象有很大的不同。其他的類型Array、Object等都會通過new操作符返回一個普通對象。盡管函數(shù)本身也是一個對象,但它與普通的對象還是有區(qū)別的,因?yàn)樗瑫r也是對象構(gòu)造器,也就是說,可以new一個函數(shù)來返回一個對象,這在前面已經(jīng)介紹。所有typeof返回“function”的對象都是函數(shù)對象。也稱這樣的對象為構(gòu)造器(constructor),因而,所有的構(gòu)造器都是對象,但不是所有的對象都是構(gòu)造器。

  既然函數(shù)本身也是一個對象,它們的類型是function,聯(lián)想到C++、Java等面向?qū)ο笳Z言的類定義,可以猜測到Function類型的作用所在,那就是可以給函數(shù)對象本身定義一些方法和屬性,借助于函數(shù)的prototype對象,可以很方便地修改和擴(kuò)充Function類型的定義,例如下面擴(kuò)展了函數(shù)類型Function,為其增加了method1方法,作用是彈出對話框顯示"function":

以下是引用片段:

Functiothod1=function(){
alert("function");
}
function func1(a,b,c){
return a+b+c;
}
func1.method1();
functhod1();

  注意最后一個語句:funchotd1(),它調(diào)用了method1這個函數(shù)對象的method1方法。雖然看上去有點(diǎn)容易混淆,但仔細(xì)觀察一下語法還是很明確的:這是一個遞歸的定義。因?yàn)閙ethod1本身也是一個函數(shù),所以它同樣具有函數(shù)對象的屬性和方法,所有對Function類型的方法擴(kuò)充都具有這樣的遞歸性質(zhì)。

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

有空看下這篇關(guān)于JS的文章

有空看下這篇關(guān)于JS的文章:函數(shù)是進(jìn)行模塊化程序設(shè)計(jì)的基礎(chǔ),編寫復(fù)雜的Ajax應(yīng)用程序,必須對函數(shù)有更深入的了解。 javascript中的函數(shù)不同于其他的語言,每個函數(shù)都是作為一個對象被維護(hù)和運(yùn)行的。通過函數(shù)對象的性質(zhì),可以很方便的將一個函數(shù)賦值給一個變量或者將函數(shù)作為參數(shù)傳遞。
推薦度:
標(biāo)簽: js 的文章 一篇文章
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产综合成人久久大片91 | 永久免费观看的毛片的网站下载 | 国产成人免费视频精品一区二区 | 北条麻妃在线播放 | 97r久久精品国产99国产精 | 国产一区二区精品久久91 | 国模大胆一区二区三区 | 国产高清在线看 | 国产精品久久久久久免费播放 | 日韩专区一区 | 美女一级毛片 | 一道本一区二区三区 | 国产精品免费视频网站 | 国产成人精品一区二区不卡 | 久久久国产这里有的是精品 | 国产第一夜 | 在线欧美a | 亚洲 欧美 成人日韩 | 极品美女国产精品免费一区 | 亚洲欧美日韩在线精品一区二区 | 国产手机精品一区二区 | 国产精品免费精品自在线观看 | 九九51精品国产免费看 | 亚洲国产精品日韩高清秒播 | 国产 日韩 欧美 综合 | 国内精品视频一区二区三区 | 日韩国产一区二区 | 极品美女国产精品免费一区 | 亚洲色图国产精品 | 91欧美精品 | 精品国产一区二区三区成人 | 欧美日韩免费 | 极品久久| 免费国产线观看免费观看 | 国内精品在线播放 | 国产精品系列在线一区 | 国产精品久久久久久永久牛牛 | 国产一二三区在线 | 看全色黄大色大片免费久久 | 国产一级高清视频免费看 | 久久噜噜 |