透過jQuery原始碼學習javascript(二)_jquery
巧妙1:函數
在javascript程式碼中函數是個不可多得的人才。
♥ 它可以歸置程式碼段,封裝相對獨立的功能。
♥ 它也可以實現類,注入OOP思想。
jQuery就是一個函數,你也可以把它當成類別(呵呵,本身就是類別)。
(function(){ jQuery = function() {
// 函數體
}
window.jQuery = window.$ = jQuery;
})();
console.log(jQuery);

巧妙2:擴充原型
何為原型物件?我給一篇部落格文章大家可以去了解
http://www.jb51.net/article/32857.htm。
javascript為所有函數綁定一個prototype屬性,由這個屬性指向一個原型物件。我們在原型物件中定義類別的繼承屬性和方法等。
原型物件是javascript實作繼承的基本機制。
(function(){
var. () {
// 函數體
}
jQuery.fn = jQuery.prototype = {
// 擴充原型物件
jquery: "1.8.3",
test: function() {
console.log('test');
}
}
window.jQuery = window.$ = jQuery;
})();
巧妙3:使用工廠方法來建立一個實例
上面的方法必須使用下面的方法才能進行調用,這樣就會產生很多對象,從而浪費記憶體消耗。
(new jQuery()).test();
(function(){
(function(){
var. () {
// 函數體
return jQuery.fn.init();
}
jQuery.fn = jQuery.prototype = {
// 擴充原型物件
jquery.prototype = {
// 擴充原型物件
jquery : "1.8.3",
init: function() {
return this;
},
test: function() {
}
}
window.jQuery = window.$ = jQuery; })();
複製代碼
程式碼如下:
(function(){
var jQuery = function() {
return this;
}
jQuery. = jQuery.prototype = {
// 擴充原型物件
jquery: "1.8.3",
test: function() {
}
}
window.jQuery = window.$ = jQuery;
})(); console.log(jQuery());
輸出結果
複製程式碼
程式碼如下:
(function(){ jQuery = function() {
return new jQuery();
}
jQuery.fn = jQuery.prototype = {
// 擴充原型物件
jquery: "1.8.3",
test: function() {
console.log('test');
}
window.jQuery = window.$ = jQuery;
})(); console.log(jQuery());
輸出結果
發現上面是遞迴死循環,出現記憶體外溢。
(function(){
var jQuery = function() {
// 函數體
return jQuery.fn.init();
}
jQuery.fn = jQuery.prototype = {
// 擴充原型物件
jquery: "1.8.3",
init: function() {
this.init_jquery = '2.0';
return this ;
}
}
window.jQuery = window.$ = jQuery;
})();
console.log(jQuery().jquery);
console.log (jQuery().init_jquery);
輸出結果

init()方法中的this作用域:this關鍵字引用了init()函數作用域所在的對象,同時也能夠存取上一層物件jQuery.fn物件的作用。 ——這種想法會破壞作用域的獨立性,對於jQuery框架來說,很可能會造成負面影響。
思考2:怎麼把init()中的this從jQuery.fn物件中分隔出來? ——實例化init初始化型別。
(function(){
(function(){
var. () {
// 函數體
return new jQuery.fn.init();
}
jQuery.fn = jQuery.prototype = {
// 擴充原型物件
jquery: "1.8.3",
init: function() {
this.init_jquery = '2.0';
return this;
}
}
window.jQuery = window.jQuery = window.jQuery = window.jQuery = window.jQuery = window.jQuery = window.jQuery = window.jQuery = window.jQuery = window.jQuery = window.jQuery = window.jQuery = window .$ = jQuery;
})();
console.log(jQuery().init_jquery);

輸出結果
透過實例化init()初始化類型,限定了init()方法裡的this,只在init()函數內活動,不讓它超出範圍。
巧妙5:原型傳遞
思考1:在巧妙4中,我們把init()中的this從jquery.fn物件中分隔出來。那我們如何能做到保證「巧妙4」的基礎上,還能存取jQuery原型物件呢? ——原型傳遞。
程式碼如下:
jQuery.fn.init.protofntype;
程式碼如下:
程式碼如下:
程式碼如下:
程式碼如下:
程式碼如下:var jQuery = function() {
// 函數體
}
jQuery.fn = jQuery.prototype = {
// 擴充原型物件jquery: "1.8.3",
return this };
}
jQuery.fn.init.prototype = jQuery.fn;
window.jQuery = window.$ = jQuery; })(); console.log(jQuery() .jquery);
console.log(jQuery().init_jquery);
輸出結果 妙棋 把init()物件的prototype指針指向jQuery.fn。 ——這樣init()裡的this繼承了jQuery.fn原型物件定義的方法和屬性。 總結 感謝博友的留言,尤其是puni ,給我介紹了一本不錯的書。如果大家能補充一下,那就再好不過了。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

如何在JavaScript中將具有相同ID的數組元素合併到一個對像中?在處理數據時,我們常常會遇到需要將具有相同ID�...

實現視差滾動和元素動畫效果的探討本文將探討如何實現類似資生堂官網(https://www.shiseido.co.jp/sb/wonderland/)中�...

學習JavaScript不難,但有挑戰。 1)理解基礎概念如變量、數據類型、函數等。 2)掌握異步編程,通過事件循環實現。 3)使用DOM操作和Promise處理異步請求。 4)避免常見錯誤,使用調試技巧。 5)優化性能,遵循最佳實踐。

深入探討console.log輸出差異的根源本文將分析一段代碼中console.log函數輸出結果的差異,並解釋其背後的原因。 �...

探索前端中類似VSCode的面板拖拽調整功能的實現在前端開發中,如何實現類似於VSCode...
