成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

javascript 理解和使用回調(diào)函數(shù)

caohaoyu / 1608人閱讀

摘要:下面我們?cè)倏磶追N回調(diào)函數(shù)。方法將會(huì)調(diào)用或執(zhí)行我們傳遞給它們的回調(diào)函數(shù)。這個(gè)例子就是一個(gè)典型的回調(diào)函數(shù)的方式。講作為參數(shù)傳遞給了,在函數(shù)內(nèi),使用回調(diào)值,在中處理這個(gè)值。使用含有對(duì)象的回調(diào)函數(shù)。出現(xiàn)這種現(xiàn)象是因?yàn)樵谌趾瘮?shù)中對(duì)象指向了對(duì)象。

在javascript中,function是內(nèi)置的類對(duì)象,也就是說(shuō)它是一種類型的對(duì)象,可以和其他String、Array、Number、Objec類的對(duì)象一樣用于內(nèi)置對(duì)象的管理。因?yàn)閒unction實(shí)際上是一種對(duì)象,它可以“存儲(chǔ)在變量中,通過(guò)參數(shù)傳遞給(另一個(gè))函數(shù)(function),在函數(shù)內(nèi)部創(chuàng)建,從函數(shù)中返回結(jié)果值”。
因?yàn)楹瘮?shù)名本身是變量,所以函數(shù)也可以作為值來(lái)使用。也就是說(shuō),不僅可以像傳遞參數(shù)一樣把一個(gè)函數(shù)傳遞給另一個(gè)函數(shù),而且可以將一個(gè)函數(shù)作為另一個(gè)函數(shù)的結(jié)果返回。

function callSomeFunction(someFunction, somaArgument) {  
    return someFunction(somaArgument);  
  }  
  
  function add(num) {  
    return num + 10;  
  }  
  var result1 = callSomeFunction(add, 10);  
  console.log(result1); // 20;  
  
  function getGreeting(name) {  
    return "hello "+ name;  
  }  
  
  var result2 = callSomeFunction(getGreeting, "world");  
  console.log(result2); // hello world;  

這個(gè)calSomeFunction()函數(shù)是通用的,即無(wú)論第一個(gè)參數(shù)中傳遞進(jìn)來(lái)的是什么函數(shù),它都返回執(zhí)行第一個(gè)參數(shù)后的結(jié)果。要訪問(wèn)函數(shù)的指針而不執(zhí)行函數(shù)的話,必須去掉函數(shù)名后的那對(duì)括號(hào)。因此上面的列子中傳遞給callSomeFunction()的是add和getGreeting,而不是執(zhí)行它們之后的結(jié)果。

下面我們?cè)倏磶追N回調(diào)函數(shù)。
在jQuery中常用的函數(shù):

$("#btn").click(function() {  
  alert("Btn  Clicked");  
})

如上面的例子,我們傳遞了一個(gè)匿名函數(shù)給click方法的形參。click方法將會(huì)調(diào)用(或執(zhí)行)我們傳遞給它們的回調(diào)函數(shù)。這個(gè)例子就是一個(gè)典型的回調(diào)函數(shù)的方式。
再看一個(gè)javascript的典型例子:

function callFunction(something) {  
    for (var item in something) {  
      console.log(item + ": " + something[item]);  
    }  
  
  }  
  
  function getSome(obj, callback) {  
    callback(obj);  
  }  
  
  getInput({name: "CSDN", lang: "Javascript"}, callFunction);  

返回的結(jié)果是CSDN:Javascript。
講callFunction作為參數(shù)傳遞給了getSome,在函數(shù)內(nèi),使用callback回調(diào)值,在calFunction中處理這個(gè)值。這樣就形成了一個(gè)很好的函數(shù)處理過(guò)程。將各段處理都分開(kāi)。
使用含有this對(duì)象的回調(diào)函數(shù)。當(dāng)回調(diào)函數(shù)是一個(gè)含有this對(duì)象的方法時(shí),我們必須修改執(zhí)行回調(diào)函數(shù)的方法以保護(hù)this對(duì)象的內(nèi)容。否則this對(duì)象將會(huì)指向全局的window對(duì)象,或者指向包含函數(shù)。

var obj = {  
    name: null,  
    setName: function (firstName, lastName) {  
      this.name = firstName + "-" + lastName;  
    }  
  }  
  
  function getName(firstName, lastName, callback) {  
    callback(firstName, lastName);  
  }  
  
  getName("Tom","Jony",obj.setName);  
  console.log(obj.name); // null  
  console.log(window.name); // Tom-Jony  

當(dāng)obj.setName被執(zhí)行時(shí),this.name 不會(huì)設(shè)置obj 對(duì)象的name,而是設(shè)置window對(duì)象中的name,因?yàn)間etName是一個(gè)全局函數(shù)。出現(xiàn)這種現(xiàn)象是因?yàn)樵谌趾瘮?shù)中this對(duì)象指向了window對(duì)象。
這個(gè)時(shí)候我們可以使用Call和Apply函數(shù)保護(hù)this對(duì)象。

var obj = {  
    name: null,  
    setName: function (firstName, lastName) {  
      this.name = firstName + "-" + lastName;  
    }  
  }  
  
  function getName(firstName, lastName, callback, callbackObj) {  
    callback.call(callbackObj, firstName, lastName);  
    // callback.apply(callbackObj, [firstName, lastName]);  
  }  
  
  getName("Tom", "Jony", obj.setName, obj);  
  console.log(obj.name); // Tom-Jony

這樣就可以通過(guò)call函數(shù)正確的設(shè)置this對(duì)象,現(xiàn)在我們可以正確的執(zhí)行回調(diào)函數(shù)并它正確地設(shè)置obj對(duì)象中的name。使用apply也是一樣的。
多重回調(diào)函數(shù)也是可以得。一個(gè)典型的例子就是jQuery的ajax函數(shù)。

function successCallback() {  
    // Do stuff before send  
}  
  
function successCallback() {  
    // Do stuff if success message received  
}  
  
function completeCallback() {  
    // Do stuff upon completion  
}  
  
function errorCallback() {  
    // Do stuff if error received  
}  
  
$.ajax({  
    url:"http://favicon.png",  
    success:successCallback,  
    complete:completeCallback,  
    error:errorCallback  
  
});    

學(xué)習(xí)前端的同學(xué)注意了!?。?br>學(xué)習(xí)過(guò)程中遇到什么問(wèn)題或者想獲取學(xué)習(xí)資源的話,歡迎加入前端學(xué)習(xí)交流群461593224,我們一起學(xué)前端!

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/112640.html

相關(guān)文章

  • javascript 回調(diào)函數(shù) 整理

    摘要:回調(diào)函數(shù)不是由該函數(shù)的實(shí)現(xiàn)方直接調(diào)用,而是在特定的事件或條件發(fā)生時(shí)由另外的一方調(diào)用的,用于對(duì)該事件或條件進(jìn)行響應(yīng)。若是使用回調(diào)函數(shù)進(jìn)行處理,代碼就可以繼續(xù)進(jìn)行其他任務(wù),而無(wú)需空等。參考理解回調(diào)函數(shù)理解與使用中的回調(diào)函數(shù)這篇相當(dāng)不錯(cuò)回調(diào)函數(shù) 為什么寫(xiě)回調(diào)函數(shù) 對(duì)于javascript中回調(diào)函數(shù) 一直處于理解,但是應(yīng)用不好的階段,總是在別人家的代碼中看到很巧妙的回調(diào),那時(shí)候會(huì)有wow c...

    xiaowugui666 評(píng)論0 收藏0
  • 理解使用Javascript中的回調(diào)函數(shù)

    摘要:在閱讀本文之后你能了解怎樣使用回調(diào)函數(shù)。這是中回調(diào)函數(shù)的典型用法,它在中廣泛被使用。這意味著回調(diào)函數(shù)本質(zhì)上是一個(gè)閉包。使用命名或匿名函數(shù)作為回調(diào)在前面的例子以及的例子中,我們使用了再參數(shù)位置定義的匿名函數(shù)作為回調(diào)函數(shù)。 轉(zhuǎn)自:張小俊128:http://www.html-js.com/articl..._luxiao:http://luxiao1223.blog.51cto.... j...

    Pandaaa 評(píng)論0 收藏0
  • 理解異步JavaScript

    摘要:當(dāng)函數(shù)結(jié)束,將會(huì)被從調(diào)用棧移出。事件循環(huán)事件循環(huán)的責(zé)任就是查看調(diào)用棧并確定調(diào)用棧是否為空。事件循環(huán)會(huì)再次檢查調(diào)用棧是否為空,如果為空的話,它會(huì)把事件回調(diào)壓入棧中,然后回調(diào)函數(shù)則被執(zhí)行。 寫(xiě)在文章前 這篇文章是翻譯自Sukhjinder Arora的Understanding Asynchronous JavaScript。這篇文章描述了異步和同步JavaScript是如何在運(yùn)行環(huán)境中,...

    ixlei 評(píng)論0 收藏0
  • 夯實(shí)基礎(chǔ)-JavaScript異步編程

    摘要:調(diào)用棧被清空,消息隊(duì)列中并無(wú)任務(wù),線程停止,事件循環(huán)結(jié)束。不確定的時(shí)間點(diǎn)請(qǐng)求返回,將設(shè)定好的回調(diào)函數(shù)放入消息隊(duì)列。調(diào)用棧執(zhí)行完畢執(zhí)行消息隊(duì)列任務(wù)。請(qǐng)求并發(fā)回調(diào)函數(shù)執(zhí)行順序無(wú)法確定。 異步編程 JavaScript中異步編程問(wèn)題可以說(shuō)是基礎(chǔ)中的重點(diǎn),也是比較難理解的地方。首先要弄懂的是什么叫異步? 我們的代碼在執(zhí)行的時(shí)候是從上到下按順序執(zhí)行,一段代碼執(zhí)行了之后才會(huì)執(zhí)行下一段代碼,這種方式...

    shadowbook 評(píng)論0 收藏0
  • ES6-7

    摘要:的翻譯文檔由的維護(hù)很多人說(shuō),阮老師已經(jīng)有一本關(guān)于的書(shū)了入門,覺(jué)得看看這本書(shū)就足夠了。前端的異步解決方案之和異步編程模式在前端開(kāi)發(fā)過(guò)程中,顯得越來(lái)越重要。為了讓編程更美好,我們就需要引入來(lái)降低異步編程的復(fù)雜性。 JavaScript Promise 迷你書(shū)(中文版) 超詳細(xì)介紹promise的gitbook,看完再不會(huì)promise...... 本書(shū)的目的是以目前還在制定中的ECMASc...

    mudiyouyou 評(píng)論0 收藏0
  • javascript 理解使用回調(diào)函數(shù)

    摘要:下面我們?cè)倏磶追N回調(diào)函數(shù)。方法將會(huì)調(diào)用或執(zhí)行我們傳遞給它們的回調(diào)函數(shù)。這個(gè)例子就是一個(gè)典型的回調(diào)函數(shù)的方式。講作為參數(shù)傳遞給了,在函數(shù)內(nèi),使用回調(diào)值,在中處理這個(gè)值。使用含有對(duì)象的回調(diào)函數(shù)。出現(xiàn)這種現(xiàn)象是因?yàn)樵谌趾瘮?shù)中對(duì)象指向了對(duì)象。 在javascript中,function是內(nèi)置的類對(duì)象,也就是說(shuō)它是一種類型的對(duì)象,可以和其他String、Array、Number、Objec類的...

    youkede 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<