国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jQuery總體架構(gòu)的理解分析

2019-11-20 23:54:47
字體:
供稿:網(wǎng)友
jQuery腳本總體結(jié)構(gòu)來說,有如下形式:
復制代碼 代碼如下:

(function( window, undefined ) {
// Define a local copy of jQueryvar jQuery = function( selector, context
) { // The jQuery object is
actually just the init constructor
'enhanced' return new
jQuery.fn.init( selector, context ); },
// Expose jQuery to the global objectwindow.jQuery =
window.$ = jQuery;
})(window);

對這樣的結(jié)構(gòu)不很理解,也沒做深究,只知道和和所謂的
Technorati 標簽: ,,
js閉包的概念相關,今天查了一些資料,有了些基本的理解。
實際是定義了一個全局函數(shù),前一個括號為一個匿名函數(shù),后面為函數(shù)的調(diào)用。可以這樣理解:
復制代碼 代碼如下:

var fun=function(window, undefined){
... ...
}
fun(window);



整個腳本是一個匿名函數(shù)(暫時叫它mainFn吧),函數(shù)被加載的時候便開始執(zhí)行,mainFn可以接收兩個參數(shù),執(zhí)行時只傳遞一個參數(shù)window.

1. 具體解釋下這個寫法的意思:
2. window 函數(shù)執(zhí)行時會傳入window,這個傳入的window是全局對象(通常為Window)的
3. 一個屬性且window=this,而傳入mainFn函數(shù)中作為其參數(shù)時,它會被存儲在
4. mainFn的調(diào)用對象中.在原型鏈中查找變量的策略是(非嵌套函數(shù)):先查找調(diào)用
5. 對象,再查找全局對象,所以這使得整個mainFn中使用的window時查找效率更高
6. undefined 由于執(zhí)行時并未傳遞第二個參數(shù),故變量undefined的值為undefined.早期版
7. 本的瀏覽器中全局對象可能沒有undefined屬性,所以不能直接使用它.通常避免
8. 這個問題的寫法是 window.undefined = window.undefined

然后在最后讓jQuery庫中最重要的對象jQuery成為了window對象的一個屬性,并可以簡寫為“$”。

其它的補充資料:
JQuery是個出色的javascript庫,最近結(jié)合它寫javascript,看了下源碼。
先從整體、全局的看,jQuery的源碼幾乎都在下面的代碼中:
復制代碼 代碼如下:

(function() {

//……

})();

第一個括號里面是個匿名函數(shù),第二個括號表示馬上執(zhí)行第一個括號里面的代碼。
首先明白,javascript里面是沒有命名空間的,要保證你的javascript函數(shù)、對象與其他的不沖突,這里用了javascript的一個技巧:你的所有javascript函數(shù)、對象都在一個匿名函數(shù)里面定義,確保了所定義的函數(shù)、對象的有效范圍,起到了命名空間的作用。既然作用范圍在這個匿名函數(shù)中,怎么被別人使用呢?下面看它的下面代碼:

var jQuery = window.jQuery = function(selector, context) {
//……
};

這里讓jQuery庫中最重要的對象jQuery成為了window對象的一個屬性,這樣就可以在其他地方像使用 document(document也是window的一個屬性)一樣使用jQuery了。也許使用過jQuery的朋友驚訝-我沒有使用jQuery對象,一直使用$的。沒錯,那是jQuery的同名對象:

window.$ = jQuery;

現(xiàn)在明白了吧。

這個庫的結(jié)構(gòu)是這樣的:
復制代碼 代碼如下:

1. (function(window, undefined){
2. var document = window.document;
3. var jQuery = ...
4. ...
5. ...
6. })(window);

(function(window, undefined){ var document = window.document; var jQuery = ... ... ... })(window);

整個腳本是一個匿名函數(shù)(暫時叫它mainFn吧),函數(shù)被加載的時候便開始執(zhí)行,mainFn可以接收兩個參數(shù),執(zhí)行時只傳遞一個參數(shù)window.
1. 具體解釋下這個寫法的意思:
2. window 函數(shù)執(zhí)行時會傳入window,這個傳入的window是全局對象(通常為Window)的
3. 一個屬性且window=this,而傳入mainFn函數(shù)中作為其參數(shù)時,它會被存儲在
4. mainFn的調(diào)用對象中.在原型鏈中查找變量的策略是(非嵌套函數(shù)):先查找調(diào)用
5. 對象,再查找全局對象,所以這使得整個mainFn中使用的window時查找效率更高
6. undefined 由于執(zhí)行時并未傳遞第二個參數(shù),故變量undefined的值為undefined.早期版
7. 本的瀏覽器中全局對象可能沒有undefined屬性,所以不能直接使用它.通常避免
8. 這個問題的寫法是 window.undefined = window.undefined
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 凤台县| 乌恰县| 海门市| 永泰县| 万州区| 宿州市| 怀集县| 通化市| 钟山县| 城固县| 图木舒克市| 民乐县| 白银市| 清丰县| 宁阳县| 农安县| 新龙县| 额尔古纳市| 正蓝旗| 盖州市| 霍城县| 虞城县| 温泉县| 乌拉特中旗| 都匀市| 胶州市| 凤山县| 新泰市| 遂宁市| 苏尼特右旗| 武城县| 林州市| 克拉玛依市| 南皮县| 高邑县| 通许县| 江油市| 萨迦县| 禄丰县| 禄丰县| 天等县|