詳細說明Javascript匿名函數技巧與文章
這樣兩種寫法都是合法的,但是意義完全不同, ***個語句創(chuàng)建了一個新的變量,而第二個是定義了window對象的一個Javascript匿名函數,相當于window.bar = 'otherthing';, 因此我們想使我們的Shaka具有這樣的調用方式能力。
Javascript匿名函數.
創(chuàng)建并執(zhí)行一個匿名函數的基本形式: (function(){ alert('Hello World!'); })(); 為什么要用到匿名函數呢,因為我們不想把Shaka的內部實現暴露出來,這樣容易與其它代碼沖突,只提供一個單一的入口,我們可以這樣測試一下:
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Strict//EN" "http://www.w3.org/TR/html4/strict.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- </head>
- <body>
- <script type="text/javascript">
- (function(){
- function privateFunction(){ alert('You can not see me, haha'); };
- })();
- function publicMethod() {alert('I am public');};
- alert('匿名函數內部的函數是不可訪問的, privateMethod 目前是: ' + typeof privateMethod);
- alert('全局函數可訪, publicMethod 目前是: ' + typeof publicMethod);
- </script>
- </body>
- </html>
然后,還有一個問題需要解決,俺們的框架做出來了但是還很簡陋,在Javascript匿名函數這之前我們需要讓它與其它的框架協(xié)同工作,因此帶來一個問題, 如果我們都使用$作為簡寫形式就會沖突了, 象jQuery一樣,我們需要提供一個noConfilit的方法“出讓”$的使用權。在我們的程序最開始處加入下面的代碼。
意思是將此前定義的$對象引用放到 _$ 中, 然Javascript匿名函數后我們再給Shaka擴展一個方法出來, 如果其它開發(fā)者需要自行擴展的話也可以使用這個方式(jQuery的extend方法提供了更為強大的功能,請大家自行研究。#t#
意思是將Shaka作為這個匿名函數的參數來調用這個方法。前面我們講過 Shaka.fn 就是 Shaka.prototype 的別名,因此我們要在Shaka.prototype 里面添加新的方法就可以寫成這樣。。