JavaScript的一些知識片段(2)-反射-全域變數-回調

來源:互聯網
上載者:User

JavaScript的一些知識片段(2)-反射-全域變數-回調
JavaScript中的反射:程式設計語言中的反射原理都一樣,就是通過操作metadata(描述語言的語言)來完成一些不具備反射功能的語言很難實現的功能。在靜態語言中,反射是一個高大上的東西,比如在運行時動態建立方法並調用,延遲綁定等等等等,當八九年前第一次用到C#的反射時,那個激動勁就別提了。但是在動態語言世界裡,很多功能不必要通過反射實現了,所以javascript的反射會變得比較簡單,因此javascript中反射的主要用法就那麼幾個如typeof ,instanceof,hasOwnProperty  var alteral={name:"a lteral"}; console.log(typeof alteral );//object console.log(alteral.hasOwnProperty("name"));//trueconsole.log(alteral.hasOwnProperty("gender"))//false; var fun = function(){var subfun=function(){return null};}; typeof(fun);console.log( fun instanceof Function); //true 全域變數: 在javascript中,你可以在任何地方隨便定義一個全域變數。小應用好像很方便,代碼成規模,切分檔案後,就完蛋了。編譯器不管,我們可以管。 兩種方式: 1.全部寫在一起,如程式最頂端,好管理。 2.寫一個全域變數的容器,在使用時把所有的全域變數都扔進去。這樣的好處也是統一管理方便檢索。 var variableBag={}  回調 在JavaScript中的實現形式是這樣的:將一個函數當做參數傳入另一個函數,這個函數會在適當的時候調用被傳入的參數。我們用一段代碼的例子來解釋:  function mainfunction(callback){//定義一個宿主函數,它接收一個callback函數作為參數。     //做一些事情,比如等待1秒鐘後,把目前時間傳給callback    var startTime = new Date().getTime();     while (new Date().getTime() < startTime + 1000);    var now = new Date().getTime();        callback(now);//調用傳入的參數}; function afunction(time){//定義callback函數    console.log("afunction is called");    console.log(time);}; mainfunction(afunction);//調用宿主函數 執行這段代碼的結果就是在等待一秒鐘後回呼函數afunction被宿主函數調用,同時宿主函數傳遞了一個參數給afunction,這一點非常重要。因為在現實中,傳遞的參數都是回呼函數要正確執行所依賴的內容。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.