前端知識體系_第1頁
前端知識體系_第2頁
前端知識體系_第3頁
前端知識體系_第4頁
前端知識體系_第5頁
已閱讀5頁,還剩5頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、2015-2016前端知識體系前端體系知識圖譜一、框架與組件bootstrap等UI框架設計與實現(xiàn)伸縮布局:grid網(wǎng)格布局基礎UI樣式:元素reset、按鈕、圖片、菜單、表單組件UI樣式:按鈕組、字體圖標、下拉菜單、輸入框組、導航組、面包屑、分頁、標簽、輪播、彈出框、列表、多媒體、警告響應式布局:布局、結構、樣式、媒體、javascript響應式第三方插件:插件管理jQuery、zepto使用原理以及插件開發(fā)支持amd、cmd、全局變量的模塊化封裝$.fn.method = function()mvc/mvvm框架原理設計,vue/angular/avalon等directive設計:htm

2、l、text、class、html、attr、repeat、ref,可擴展filter設計:bool、upperCase、lowerCase,可擴展表達式設計:if-else等實現(xiàn)viewmodel結構設計:例如數(shù)據(jù),元素,方法的掛載與作用域數(shù)據(jù)更變檢測:函數(shù)觸發(fā),臟數(shù)據(jù)檢測、對象hijackingpolymer/angular2思想與設計思路import技術template和script引入方式css樣式命名空間隔離簡單復用第三方庫reactjs原理與使用virtual dom單向數(shù)據(jù)綁定js執(zhí)行語法方式UI由狀態(tài)控制commonJS/AMD/CMD模塊引入模塊定義模塊標識UMD解決不同規(guī)范

3、兼容性的問題,例如webpack封裝模塊懶執(zhí)行(CMD)與與預執(zhí)行(AMD)loadJs模塊化加載原理與實現(xiàn)創(chuàng)建script標簽,需要id映射到資源urlonload加載模塊隊列判斷全部加載完成后觸發(fā)加載失敗問題優(yōu)化requirejs、modjs、seajspolyfill、shim原理與實現(xiàn)polyfill提供了開發(fā)者們希望瀏覽器原生提供支持的功能特性shim將新的API引入到舊的環(huán)境中,且僅靠舊環(huán)境中已有的手段實現(xiàn)virtual Dom、Incremental DOM1.用js對象樹表示dom樹結構,根據(jù)該對象樹構建dom樹2.狀態(tài)改變時,重新構建對象,和舊的對象對比,記錄兩個對象樹差異3

4、.將對象樹差異應用到dom中小結:js對象模擬dom(elem.js),virtual dom diff算法(diff.js)、差異渲染dom(patch.js)incremental dom在狀態(tài)改變時掃描舊對象樹將差異直接應用到dom中shadow dom隔離外部環(huán)境用于封裝組件:結構、樣式、行為實現(xiàn)形式:新標簽、class類屬性 + 構建編譯webwork與service Workerwebwork與主線程機制,on/postserviceworker可作為瀏覽器請求代理應用場景ES6轉(zhuǎn)ES5、Babel與ES6開發(fā)規(guī)范體系ES6編碼規(guī)范全ES6在babel下兼容性ES6在node下兼容

5、性與性能ES6新特性:看編碼規(guī)范aurelia ES6前端框架Isomorphic JavaScript同構原理同構方案 Rendrnodejs: 服務器hapi: 應用服務backbone.js: 后臺mvcrequirejs: 模塊加載jquery: dom處理reactjs同構:React + Flux + Koa雙向數(shù)據(jù)綁定函數(shù)觸發(fā):vuejs臟數(shù)據(jù)檢測:angular對象hijacking:avalonbrowserify運行原理1.從入口模塊開始分析require函數(shù)調(diào)用2.根據(jù)依賴生成AST3.根據(jù)AST找到每個模塊的模塊名4.得到每個模塊的依賴關系,生成一個依賴字典5.包裝每個

6、模塊(傳入依賴字典以及export和require函數(shù)),生成執(zhí)行的jsperformance timingperformance timing apiperformance timing 過程performance timing 性能計算performanceTrace庫組件UI與js組件規(guī)范化組件編碼規(guī)范組件目錄規(guī)范:組件目錄與公用目錄組件構建規(guī)范:構建環(huán)境支持組件模塊化管理:spm,bowserify組件復用性管理第三方組件接入成本immutable JavaScriptgenerator與promise原理與使用二、構建生態(tài)grunt/gulp開發(fā)環(huán)境任務編寫文件處理插件:html、s

7、css、js、image、font、其它優(yōu)化插件:雪碧圖、圖片壓縮、iconfont構建發(fā)布替換插件打包、壓縮包插件:組件自動分析白名單配置自定義插件編寫npm、jspm、bower包管理工具r.js、browserify、webpack、webpack 2、Rollup打包工具使用原理:根據(jù)依賴配置文件對文件進行依賴打包webpack支持更多的規(guī)范打包,AMD,Commonjswebpack+babel/reactjs+refluxfis3構建與插件開發(fā)、構建環(huán)境、fis3構建離線包web Component:rosetta-org、x-view、Q、riot、novabrunch構建工具三

8、、開發(fā)技巧與調(diào)試fiddler加willow基礎組合調(diào)試常見配置與分析結合瀏覽器調(diào)試werien、vorlonjs遠程調(diào)試,chrome inspectmockjs,F(xiàn).M.S(Front Mock Server)模擬調(diào)試使用與cgi自動調(diào)試macha/phantomjs/casperjs/karma測試自動化任務使用自動化UI測試,海豚node-supervior、node-inspector、karma開發(fā)發(fā)布系統(tǒng)流程sublime高效插件emmet工具使用、 sublimelinter、 babel snippets、 sublimeLint、 SassBeautify 、 emmet

9、快速編輯、 jsxlint、 SideBarEnhancements、 SnippetsMaker、 SublimeCodeIntel、 css snippets、 ColorPicker、 html/css/js Pretty、 SpinnetMacker、 DocBlockr、 MultiEditUtils、 javascript & node spinnet、 JavaScript & NodeJS Snippets、 jsLint、cssLint代碼自動化檢查fecs四、html、css與重構jpeg、webp、apng、bpg圖片編碼原理特點與優(yōu)劣勢適用場景iconf

10、ont使用與實現(xiàn)原理自動打包構建方法iconfont兼容性寫法fonthello、fontawesome、icomoon.io、線上工具頁面響應式設計layout布局響應式html結構響應式css樣式響應式image媒體響應式javascript響應式media query與平臺判斷css重置resetnomalizeneatsass/compass/less/postcss常用語法與使用常用語法功能組件化UI設計管理構建工具實現(xiàn)方案雪碧圖自動合成iconfont自動接入等等media query與常見頁面尺寸了解媒體類型引入和媒體特性引入device-width適應retina屏幕適應em,

11、rem原理與實現(xiàn)rem計算:width*retina/10,相當于屏幕寬度為10rem字體在rem情況下仍然使用pxcode4ui、code4app、初頁、maka等前端dom操作即使刷新前端頁面根據(jù)dom操作生成組件config配置保存到db根據(jù)config配置使用r.js或webpack打包發(fā)布打包后輸出文件css3動畫transformanimationtransiction3D加速與動畫加速動畫庫緩動函數(shù)速查表: Ceaser: cubic-bezier:http:/cubic-css網(wǎng)格布局susyResponsive Grid SystemFluid 960 Grid(adaptj

12、s)Simple Grid搜索引擎與前端SEOtdk優(yōu)化頁面內(nèi)容優(yōu)化唯一的H1標題img設置alt屬性nofollowurl優(yōu)化統(tǒng)一鏈接301跳轉(zhuǎn)canonicalrobot優(yōu)化robots.txtmeta robotssitemapSEO工具各種站長工具等瀏覽器緩存種類,resources,webSQL,indexDB, localstorage,cookie,app cache,cache storagestore.js、cookie.jsUI框架bootstrap、jqwidgets、semantic ui、amaze ui微信手Q ui: frozenui、weui、blend uie

13、xtjs、echart圖表ui五、native/hybrid/桌面開發(fā)ionic移動開發(fā)方案運行架構hybrid混合開發(fā)cordova交互離線包更新性能瓶頸nativescript移動開發(fā)方案react Native移動開發(fā)方案運行架構:js引擎性能缺陷與內(nèi)存泄露更新機制使用場景android/ios原生開發(fā)與框架javaoc、swiftweb與native交互屏幕旋轉(zhuǎn)搖一搖錄像,拍照,選取本地圖片打電話,發(fā)短信電池電量地理位置日期選擇開啟硬件加速桌面應用開發(fā)nodewebkitatom-shell(后改名為electron)網(wǎng)易Hex pomelo(游戲服務器框架)react desktop

14、appjs:六、前端/H5優(yōu)化(另一個圖已給出)yslow、pagespeed移動web性能優(yōu)化手機瀏覽器"省流量"原理增量更新原理及注意事項本地存儲的應用加載優(yōu)化圖片優(yōu)化單頁面及路由實現(xiàn)業(yè)內(nèi)著名站點案例分析七、全棧/全端開發(fā)express/node club + mongodb、thinkjs等框架node.js直出實時web開發(fā),meteor/express.ioMEAN(mongodb/express/angular/nodejs)http與http2協(xié)議、bigpipe、pipeline離線緩存,cookie、localstorage、indexdbcdn與dns動

15、態(tài)域名加速cdn原理與cdn combo八、研究實驗WebAssembly、webTRC、typescriptMaterial design規(guī)范的前端框架交互動效庫AMP-HTML規(guī)范使用受限HTML以及緩存技術來提高移動網(wǎng)絡中靜態(tài)內(nèi)容的性能添加自定義的元素代替禁用掉的元素:amp-audio, amp-img、amp-video等九、數(shù)據(jù)分析與監(jiān)控badjs數(shù)據(jù)上報捕獲錯誤兩種方法:onerror、try-catch。抽樣上報,先onerror統(tǒng)計語法錯誤,如果是script error,再使用tryjs。后臺統(tǒng)計方法、不同業(yè)務接入體系、抽樣統(tǒng)計onerror:可以捕捉語法錯誤和運行時錯誤;可以拿到出錯的信息,堆棧,出錯文件、行號、列號;當前頁面執(zhí)行的js腳本出錯都會捕捉到;跨域的資源需要特殊頭部支持。try-catch:無法捕捉語法錯誤,只能捕捉運行時錯誤;可以拿到出錯的信息,堆棧,出錯文件、行號、列號;需要借助工具把function塊以及文件塊加入try,catch,可以在這個階段打入更多的靜態(tài)信息。點擊熱力圖clickHeat、heatMapjs加載失敗優(yōu)化方案失敗重發(fā)機制加載源域名服

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論