一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

Javascript匿名函數的一種應用 代碼封裝

在一些Javascript庫中可以看見這種寫法:
復制代碼 代碼如下:
(function(){
//所有庫代碼代碼
})();

說實話,對于js初學者的我來說。這個東西太嚇人了,在這些JS庫中,這個函數基本上把整個庫的所有代碼全括起來了,這種寫法完全超越了我的常識。難道不應該好好的劃分一下嗎,難道不應該體現出層次和功能劃分嗎,怎么會一個函數搞定呢。我一開始完全不敢去細想它的道理。直到使用JS一段時間后,某一天一位同事在閑聊時說起了這個問題,我才知道這個叫匿名函數。匿名函數我并不陌生,C#,Python,Lua中都有這個咚咚。我到網上去查了一下,介紹文章很多,也很詳細,但是我心頭的疑問卻沒有得到解決:為什么要這樣寫。
我找了一款著名的JS開源庫JQuery,他的代碼就是典型的以上寫法,在粗略看了他的代碼之后我發現這套代碼實在太大了太復雜了,實在不適合我。于是我轉而去看另外一個開源js庫swfobject,這個庫提供了簡單的接口把Flash控件嵌入到網頁中。這個代碼好多了,很短,很快就看完了。看完之后我恍然大悟,原來如此。真理就是如此簡單,之所以這樣寫,只有一個目的:封裝。
初學JS的時候,我問過同事,js怎么定義私有函數和變量。當時的得到的答案是:js不是面向對象的,不提供這些功能。我對這個答案也坦然接受了,畢竟嚴格的封裝并不是必要的。現在終于明白了,辦法總是有的,在不支持封裝的語言里同樣可以實現封裝。而實現的方法就是匿名函數。來看一段代碼:
復制代碼 代碼如下:
//定義
function F(x)
{
this.x = x;
function double(x){return x*x;}
this.getDoubleX(){
return double(this.x);
}
}

//使用
f = new F(12);
alert(f.getDoubleX());


上面的代碼很簡單,我沒有去運行它。懂點js的都知道這是JS的類定義方式。函數F相當于一個構造函數,而函數里面的其他定義都是函數私有的外部無法訪問,例如double函數。這樣就變相實現了私有方法。其他打上“this.”前綴的成員相當于公開成員,外部可以訪問。
而這些庫之所以要用一個大函數包裹整個庫代碼,就是為了不向使用者暴露內部方法和變量,強制用戶只能訪問開放的API。從這一點可以開出這些開發者的良苦用心。
到這里我不禁又要問了,js如何實現繼承呢。希望這一次的答案不要像上一次一樣:不支持。

JavaScript技術Javascript匿名函數的一種應用 代碼封裝,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 91av在线导航 | 韩国午夜理伦三级2020宅男 | 在线视频 91 | 午夜国产精品免费观看 | 国产成人+综合亚洲+天堂 | 欧美激情视频在线观看免费 | 国产一区福利 | 黄色大片久久 | 大色皇大久久大久久 | 久久国产精品免费观看 | 国产免费看视频 | 午夜欧美福利视频 | 亚洲妇人成熟性成熟美女 | 八戒精品无人区1区2区3区 | 加勒比一本大道在线 | 免费色网址 | 小视频在线 | 国产黄色免费在线观看 | 伊人精品视频在线观看 | 在线a视频网站 | 国产成人女人在线视频观看 | 婷婷激情五月 | 欧美综合在线视频 | 久久国产加勒比精品无码 | 黄网址在线观看 | 亚洲欧美激情综合第一区 | 午夜激情视频在线观看 | 国产亚洲精品hd网站 | 亚洲无吗在线视频 | 国产第一页在线播放 | 玖玖国产精品视频 | 亚洲国产成人久久午夜 | 国产高清视频网站 | 五月婷婷影视 | 欧美超级碰碰 | 综合爱| 美女掰开逼 | 欧美成人午夜精品免费福利 | 日韩中文字幕在线免费观看 | 2021国产成人精品国产 | www.日本黄 |