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,這一點非常重要。因為在現實中,傳遞的參數都是回呼函數要正確執行所依賴的內容。