前端架構體系技術_第1頁
前端架構體系技術_第2頁
前端架構體系技術_第3頁
前端架構體系技術_第4頁
前端架構體系技術_第5頁
已閱讀5頁,還剩20頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、前端架構體系技術一、框架與組件bootstrap等UI框架設計與實現伸縮布局:grid網格布局基礎UI樣式:元素。$就、按鈕、圖片、菜單、表單組件UI樣式:按鈕組、字體圖標、下拉菜單、輸入框組、 導航組、面包屑、分頁、標簽、輪播、彈出框、列表、多媒 體、警告響應式布局:布局、結構、樣式、媒體、javascript響應式第三方插件:插件管理jQuery、zepto使用原理以及插件開發(fā)支持amd、cmd、全局變量的模塊化封裝$.fn.method = function() mvc/mvvm框架原理設計directive 設計:html、text、class、html、attr、repeat、ref

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

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

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

5、 ES6前端框架Isomorphic JavaScript同構原理同構方案Rendrnodejs:服務器hapi:應用服務backbone.js:后臺 mvcrequirejs:模塊加載jquery: dom 處理reactjs 同構:React + Flux + Koa雙向數據綁定函數觸發(fā):vuejs臟數據檢測:angular 對象 hijacking:avalonbrowserify 運行原理.從入口模塊開始分析require函數調用.根據依賴生成AST.根據AST找到每個模塊的模塊名.得到每個模塊的依賴關系,生成一個依賴字典.包裝每個模塊(傳入依賴字典以及export和require函數

6、), 生成執(zhí)行的jsperformance timingperformance timing api performance 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、scss、js、image、font、其

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

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

9、 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)劣勢適用場景iconfont使用與實現原理自動打包構建方法iconf

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

11、dth*retina/10,相當于屏幕寬度為10rem字體在rem情況下仍然使用pxcode4ui、code4app、初頁、maka 等前端dom操作即使刷新前端頁面根據dom操作生成組件config配置保存到db根據config配置使用r.js或webpack打包發(fā)布打包后輸出文件css3動畫 transformanimation transiction3D加速與動畫加速動畫庫緩動函數速查表: HYPERLINK /easeing/easeing/ /easeing/easeing/Ceaser: HYPERLINK /easeing/ceaser/ /easeing/ceaser/cubi

12、c-bezier: HYPERLINK / /css網格布局susyResponsive Grid SystemFluid 960 Grid(adaptjs)Simple Grid搜索引擎與前端SEOtdk優(yōu)化頁面內容優(yōu)化唯一的H1標題img設置alt屬性nofollowurl優(yōu)化統(tǒng)一鏈接301跳轉 canonicalrobot優(yōu)化robots.txtmeta robotssitemapSEO工具各種站長工具等瀏覽器緩存種類, resources,webSQL,indexDB, localstorage,cookie,app cache,cache storagestore.js、cookie

13、.jsUI框架 bootstrap、jqwidgets、semantic ui、amaze ui微信手 Q ui: frozenui、weui、blend ui extjs、echart 圖表 ui五、native/hybrid/桌面開發(fā)ionic移動開發(fā)方案運行架構hybrid混合開發(fā) cordova 交互離線包更新性能瓶頸nativescript移動開發(fā)方案reactNative移動開發(fā)方案運行架構:js引擎性能缺陷與內存泄露更新機制使用場景android/ios原生開發(fā)與框架 javaoc、swift web與native交互屏幕旋轉搖一搖錄像,拍照,選取本地圖片打電話,發(fā)短信電池電量地

14、理位置日期選擇開啟硬件加速桌面應用開發(fā)nodewebkit atom-shell(后改名為 electron)網易Hexpomelo(游戲服務器框架)react desktopappjs:六、前端/H5優(yōu)化(另一個圖已給出)yslow、pagespeed移動 web性能優(yōu)化手機瀏覽器”省流量”原理增量更新原理及注意事項本地存儲的應用加載優(yōu)化圖片優(yōu)化單頁面及路由實現業(yè)內著名站點案例分析七、全棧/全端開發(fā)express/nodeclub + mongodb、thinkjs 等框架 node.js 直出實時 web 開發(fā), meteor/express.ioMEAN(mongodb/express/

15、angular/nodejs)http 與 http2 協(xié)議、bigpipe,pipeline 離線緩存,cookie、localstorage、 indexdbcdn 與 dns動態(tài)域名加速cdn 原理與 cdn combo八、研究實驗 WebAssembly、webTRC、typescriptMaterial design規(guī)范的前端框架交互動效庫AMP-HTML 規(guī)范使用受限HTML以及緩存技術來提高移動網絡中靜態(tài)內容 的性能添加自定義的元素代替禁用掉的元素:amp-audio, amp-img、 amp-video 等九、數據分析與監(jiān)控badjs數據上報捕獲錯誤兩種方法:onerror、

16、try-catch。抽樣上報,先onerror統(tǒng)計語法錯誤,如果是script erro一再使用 tryjs。后臺統(tǒng)計方法、不同業(yè)務接入體系、抽樣統(tǒng)計onerror:可以捕捉語法錯誤和運行時錯誤;可以拿到出錯的信 息,堆棧,出錯文件、行號、列號;當前頁面執(zhí)行的js腳本 出錯都會捕捉到;跨域的資源需要特殊頭部支持。try-catch:無法捕捉語法錯誤,只能捕捉運行時錯誤;可以拿 到出錯的信息,堆棧,出錯文件、行號、列號;需要借助工 具把function塊以及文件塊加入try,catch,可以在這個階段 打入更多的靜態(tài)信息。點擊熱力圖clickHeat、heatMapjs加載失敗優(yōu)化方案失敗重發(fā)機制加載源域名服務器文件https反劫持 百度alog數據上報十、其它軟技能axure原型圖設計xmind腦圖管理效率管理cani use、github知識管理/總結

溫馨提示

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

評論

0/150

提交評論