逐行分析jquery源碼
⑴ 完全理解jQuery源代碼,在前端方面算什麼水平
總體來講,涉及前端的知識體系比較繁多,從最基本的HTML、CSS、JS,再到一些類庫框架(jQuery、Bootstrape、seaJS等),以及各種開發規范(W3C、AMD、CMD等),以及多種前端應用技術(json、xml、ajax等),還有各種前端生態系統(FIS、Yeomen等)神握,還要熟悉多種IDE工具及bug調試工具的使用(myeclipse、VS、DW、PS、AI、sublime、firebug、console控制台等),還要了解一大堆與Web相關的知識(性能、網路、Web安全、SEO、cookies、CDN、瀏覽器兼容性等)。
綜上所述,如果單憑「完全理解jQuery源代則消碼」這一條來作為評判前端水平的條件的話,我只能說這個人在JS上是個高手,很可能是個優秀的JS工游盯慶程師,但無法判斷其前端水平。
⑵ jquery源碼實現原理(jquery源碼分析筆記)
深入分析JQuery和javaScript的異同1、所以最本質的區別就是js是一種語言,而jQuery是基於該語言的一種框架。除卻最本質的區別還有一些用法上的差別。
2、jquery是建構在javascript之上的框架。。JAVASCRIPT是編程語言,寫JAVASCRIPT的過程,就是一種真正的編程。。而jquery可以看作是在JAVASCRIPT上套了一層皮。
3、jquery和javascript的區別主要是包含關系,而jquery擴展更多JavaScript一種直譯式腳本語言,是一種動態類型、弱類型、基於原型的語言,內置支持類型。
ajax在jquery的底層是怎麼實現的呢?
1、ajax()方法通過HTTP請求載入遠程數據。該方法是jQuery底層AJAX實現。簡單易用的高層實現見$.get,$.post等。$.ajax()返回其創建的XMLHttpRequest對象。
2、通過HTTP請求載入遠程數據。jQuery底層AJAX實現。簡單易用的高層實現見$.get,$.post等。$.ajax()返回其創建的XMLHttpRequest對象。
3、Ajax全稱是asynchronousjavascriptandxml,主要用來實現客戶端與伺服器端的非同步通信效果,實現頁面的局部刷新,從而創建快速動態網頁的技術。
4、它有自帶的ajax方法啊。比如$.get(URL,callback);或者post也可以。這2個我覺得用著比較簡單。
5、大家知道,調用jQuery有兩種方式,一種是高級的實現,通過傳遞一個參數實現DOM選擇,如通過$(「h1″)選擇所有的h1元素,第二種是較為低級的實現,如果通過$.ajax實現ajax的操作。
求jquery的trigger()方法原理trigger是觸發對象事件的,這里trigger(click)實際上是觸發了a標簽的onclick事件,並不是說觸發了用戶點擊事件,因此是無效的。
從上面定義可以看出此方法和trigger()方法功能上很類似,但還是有巨大區別。以下是主要區別:此方法不會觸發瀏覽器默認事件。此方法觸發jQuery對象集合中第一個元素的事件處理函數,不會產生事件冒泡。
trigger(event,[data])在每一個匹配的元素上觸發某類事件。這個函數也會導致瀏覽器同名的默認行為的執行。比如,如果用trigger()觸發一個』submit』,則同樣會導致瀏覽器提交表單。如果要阻止這種默認行為,應返回false。
$(#btn).click();觸發自定義事件trigger()方法不僅能觸發瀏覽器支持的具有相同名稱的事件,也可以觸發自定義名稱的事件。
⑶ 如何正確閱讀jquery源碼和jquery插件源碼
1. jQuery 裡面有很多東西是出於兼容性,歷史遺留。
比如 .ready() 之類的函數,為什麼會很scroll 有關,那是為了兼容某些ie。這種代碼對於編程思想來說不僅沒用,而且是雜音,你要篩選出來就得了解這段代碼的變動,費心費力得不償失。
2. jQuery 裡面的代碼不一定是最優的,例如事件委託,每一次事件觸發都要調用選擇器,實際上是效率很低的。但是我又比較懶,沒有提交patch。
3. jQuery 實際上很容易寫出來一個 barebone alternative,在使用的過程中多想,多思考多總結就可以了。
4. jQuery 這類框架里真正有思維挑戰性的東西不多,一半以上是堆代碼而已,剩下的一點價值在於架構、抽象、擴展能力。
5. 我有一句話與所有的同行分享:工程師讓需求成為現實,優秀工程師化復雜為簡單,頂尖工程師變不可能為可能;架構師掌握現在,優秀架構師展望未來,頂尖架構師創造時代。
jQuery 的設計目的是,讓前端工程師的工作更簡單更輕松,但它並不適合所有的前端工程師,假如你的目標是成為優秀架構師、頂尖架構師的話,你在jQuery里也看不清未來。