亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
似懂非懂啊
第一章:1-5、1-6
第二章:2-1、2-2、2-3
第三章:3-1、3-2、3-5 callbacks解決的問題;3-4 callbacks的應用;剩下的把源碼看懂
第一章:1-5、 1-6
第二章:2-1、2-2、2-3
第一章:1-5、 1-6
@liumengyang 一開始看的時候還在想 當 otpions存在時只取了optionsCache[options] , 可是在createOptions這個函數中只有optionsCache[options] = {} 沒有對它進行操作啊。過了一會兒突然想起來在js里 對象賦值不是單純的值賦值而是地址復制,所以其實 var object = optionsCache[options] = {}; 指向了同一個對象。頓時體會到了這行代碼的精妙。
有兩個點:
1、callbacks.fired() 的用途官方解釋是“Determine if the callbacks have already been called at least once.”檢測callbacks對象的回調列表是否被調用過至少一次。
2、callbacks.fireWith( [ context ][ ,args ] ) :訪問給定的上下文和參數列表中的所有回調 -> 將回調中的this值指向傳入的context參數。
了解了js的new機制,以及prototype,prototype.constructor相關知識就能明白這里。
課程說的太繞了,反而把人繞暈。況且有些理解,并不一定適合。
這個“課程”到這里,感覺組織的不是太好,有點蜻蜓點水走馬觀花的味道。
如果是技術類文章,這樣還是不錯。但作為“課程”,就不夠了,課程目標和組織形式都很模糊。
使用了jQuery可以做到以下的幾點:

1.簡潔的API

2.優雅的鏈式調用

3.強大的選擇器

4.便捷的操作

執行一個動畫,需要設計的東西:

瀏覽器的兼容、各種屬性的獲取、邏輯流程、性能等等。
DOM對象容易產生內存泄漏是因為IE9之前的瀏覽器的DOM和BOM中的對象就是使用C++以COM對象的形式實現的,而又COM對象的垃圾回收機制采用的就是引用計數策略。所以只有在IE9之前關于DOM對象的循環引用才會產生內存泄漏,IE9以后的DOM不再是使用COM實現了,換成了真正的JavaScript對象了
更多關于內存泄漏的可以參考這篇博文:http://blog.csdn.net/ronghuimo/article/details/78872382
有小伙伴說
$.fn.init.prototype = $.fn; 是$.fn.init繼承了$,其實是不對的,這里并沒有繼承,唯一作用就是讓$.fn.init.prototype指向$.fn,這樣一來init實例對象調用each方法會到$.fn.init.prototype上查找,也就是到$.fn上查找,由于$.fn上有each方法所以找到了,可以調用。如果說真要想$.fn.init繼承$,則應該這么寫:
$.fn.init.prototype.prototype = $.fn;或者$.fn.init.prototype = Object.create($.fn)
new操作主要分為四步:
(1)新創建一個空對象{}
(2)建立原型鏈接(新建立的這個空對象.__proto__指向構造函數.prototype)
(3)this綁定 (當前this指向那個新創建的對象)
(4)返回對象(不設置return的話默認返回當前新創建的對象,否則return設置什么則返回什么)
$(selector,context)用于返回一個jq類數組對象,這個對象如何產生然后返回呢?通過new的方式對init函數進行構造調用,這個init函數我們打算綁在哪呢?打算綁在jquery.prototype上,每次一長串jquery.prototype是不是覺得太長了?那我們用jquery.fn來簡寫吧。于是出現了
jquery.fn=jquery.prototype={
init:function(){}
};
可這樣會導致重寫原型對象,jquery.prototype的constructor指向意外丟失了,那我們重新給其設置一下
constructor指向jquery吧
get方法最好定義在aQuery.prototype上,而不是直接定義在給每個實例對象上,這樣模仿jquery更像些
課程須知
源碼的閱讀不是一蹴而就的,需要大家有一定的功底,比如jQuery的基礎運用以及API的熟悉度,除此之外要有牢固的javascript、DOM、CSS的基礎功底,甚至還需要理解常見的設計模式、數據結構等等。當然大家也不要被這些給嚇住了,理解,總是需要一種慢慢的學習過程。
老師告訴你能學到什么?
通過本課程的學習,您可以由淺入深地剖析jQuery庫的設計與實現。 其中我們圍繞的重心: 1、設計理念 2、結構組織 3、接口設計 4、模式運用 5、場景套用

微信掃碼,參與3人拼團

微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

友情提示:

您好,此課程屬于遷移課程,您已購買該課程,無需重復購買,感謝您對慕課網的支持!

本次提問將花費2個積分

你的積分不足,無法發表

為什么扣積分?

本次提問將花費2個積分

繼續發表請點擊 "確定"

為什么扣積分?

舉報

0/150
提交
取消