伸縮佈局:grid網格佈局javascript
基礎UI樣式:元素reset、按鈕、圖片、菜單、表單css
組件UI樣式:按鈕組、字體圖標、下拉菜單、輸入框組、導航組、麪包屑、分頁、標籤、輪播、彈出框、列表、多媒體、警告html
響應式佈局:佈局、結構、樣式、媒體、javascript響應式前端
第三方插件:插件管理vue
支持amd、cmd、全局變量的模塊化封裝html5
$.fn.method = function(){}java
directive設計:html、text、class、html、attr、repeat、ref,可擴展node
filter設計:bool、upperCase、lowerCase,可擴展react
表達式設計:if-else等實現jquery
viewmodel結構設計:例如數據,元素,方法的掛載與做用域
數據更變檢測:函數觸發,髒數據檢測、對象hijacking
import技術
template和script引入方式
css樣式命名空間隔離
簡單複用第三方庫
virtual dom單向數據綁定
js執行語法方式
UI由狀態控制
模塊引入
模塊定義
模塊標識
UMD解決不一樣規範兼容性的問題,例如webpack封裝
模塊懶執行(CMD)與與預執行(AMD)
建立script標籤,須要id映射到資源url
onload加載模塊隊列判斷
所有加載完成後觸發
加載失敗問題優化
requirejs、modjs、seajs
polyfill提供了開發者們但願瀏覽器原生提供支持的功能特性
shim將新的API引入到舊的環境中,且僅靠舊環境中已有的手段實現
1.用js對象樹表示dom樹結構,根據該對象樹構建dom樹
2.狀態改變時,從新構建對象,和舊的對象對比,記錄兩個對象樹差別
3.將對象樹差別應用到dom中
小結:js對象模擬dom(elem.js),virtual dom diff算法(diff.js)、差別渲染dom(patch.js)
incremental dom在狀態改變時掃描舊對象樹將差別直接應用到dom中
隔離外部環境用於封裝組件:結構、樣式、行爲
實現形式:新標籤、class類屬性 + 構建編譯
webwork與主線程機制,on/post
serviceworker可做爲瀏覽器請求代理
應用場景
ES6編碼規範全
ES6在babel下兼容性
ES6在node下兼容性與性能
ES6新特性:看編碼規範
aurelia ES6前端框架
同構原理
同構方案 Rendr
nodejs: 服務器
hapi: 應用服務
backbone.js: 後臺mvc
requirejs: 模塊加載
jquery: dom處理
reactjs同構:React + Flux + Koa
函數觸發:vuejs
髒數據檢測:angular
對象hijacking:avalon
1.從入口模塊開始分析require函數調用
2.根據依賴生成AST
3.根據AST找到每一個模塊的模塊名
4.獲得每一個模塊的依賴關係,生成一個依賴字典
5.包裝每一個模塊(傳入依賴字典以及export和require函數),生成執行的js
performance timing api
performance timing 過程
performance timing 性能計算
performanceTrace庫
組件編碼規範
組件目錄規範:組件目錄與公用目錄
組件構建規範:構建環境支持
組件模塊化管理:spm,bowserify
組件複用性管理
第三方組件接入成本
文件處理插件:html、scss、js、image、font、其它
優化插件:雪碧圖、圖片壓縮、iconfont構建
發佈替換插件
打包、壓縮包插件:組件自動分析
白名單配置
自定義插件編寫
原理:根據依賴配置文件對文件進行依賴打包
webpack支持更多的規範打包,AMD,Commonjs
webpack+babel/reactjs+reflux
常見配置與分析
結合瀏覽器調試
編碼原理
特色與優劣勢
適用場景
自動打包構建方法
iconfont兼容性寫法
fonthello、fontawesome、icomoon.io、iconfont.cn線上工具
layout佈局響應式
html結構響應式
css樣式響應式
image媒體響應式
javascript響應式
media query與平臺判斷
reset
nomalize
neat
經常使用語法功能
組件化UI設計管理
構建工具實現方案
雪碧圖自動合成
iconfont自動接入等等
媒體類型引入和媒體特性引入
device-width適應
retina屏幕適應
rem計算:width*retina/10,至關於屏幕寬度爲10rem
字體在rem狀況下仍然使用px
前端dom操做即便刷新前端頁面
根據dom操做生成組件config配置保存到db
根據config配置使用r.js或webpack打包
發佈打包後輸出文件
transform
animation
transiction
3D加速與動畫加速
動畫庫
cubic-bezier:http://cubic-bezier.com/
susy
Responsive Grid System
Fluid 960 Grid(adaptjs)
Simple Grid
tdk優化
頁面內容優化
惟一的H1標題
img設置alt屬性
nofollow
url優化
統一連接
301跳轉
canonical
robot優化
robots.txt
meta robots
sitemap
SEO工具
各類站長工具等
bootstrap、jqwidgets、semantic ui、amaze ui
微信手Q ui: frozenui、weui、blend ui
extjs、echart圖表ui
運行架構
hybrid混合開發
cordova交互
離線包更新
性能瓶頸
運行架構:js引擎
性能缺陷與內存泄露
更新機制
使用場景
java
oc、swift
web與native交互
屏幕旋轉
搖一搖
錄像,拍照,選取本地圖片
打電話,發短信
電池電量
地理位置
日期選擇
開啓硬件加速
nodewebkit
atom-shell(後更名爲electron)
網易Hex
pomelo(遊戲服務器框架)
react desktop
appjs:appjs.com
手機瀏覽器"省流量"原理
增量更新原理及注意事項
本地存儲的應用
加載優化
圖片優化
單頁面及路由實現
業內著名站點案例分析
動態域名加速
cdn原理與cdn combo
使用受限HTML以及緩存技術來提升移動網絡中靜態內容的性能
添加自定義的元素代替禁用掉的元素:amp-audio, amp-img、amp-video等
捕獲錯誤兩種方法:onerror、try-catch。抽樣上報,先onerror統計語法錯誤,若是是script error,再使用tryjs。
後臺統計方法、不一樣業務接入體系、抽樣統計
onerror:能夠捕捉語法錯誤和運行時錯誤;能夠拿到出錯的信息,堆棧,出錯文件、行號、列號;當前頁面執行的js腳本出錯都會捕捉到;跨域的資源須要特殊頭部支持。
try-catch:沒法捕捉語法錯誤,只能捕捉運行時錯誤;能夠拿到出錯的信息,堆棧,出錯文件、行號、列號;須要藉助工具把function塊以及文件塊加入try,catch,能夠在這個階段打入更多的靜態信息。
失敗重發機制
加載源域名服務器文件
https反劫持
w3c tech、w3c plus、w3 help
div.io、nodeParty
稀土掘金、前端早讀課
alloyteam、html5基地
W3 help
segmentfault會議
深js、杭js
GMIC(全球移動互聯網大會)
D二、webrebuild
infoQ內容、Qcon、velocity