前端性能優(yōu)化基礎知識

這篇文章主要介紹一些前端性能優(yōu)化的術語定義優(yōu)化出發(fā)點

性能優(yōu)化基礎知識

技術優(yōu)化出發(fā)點

復用

很多時候我們開發(fā)都會復用一些模塊巢株,這是減少開發(fā)成本惠毁,比如造輪子犹芹。當然,在性能優(yōu)化方面鞠绰,復用也是非常重要的一點腰埂。

  • 文件復用
    文件復用是一種工程化的開發(fā)方式,比如說我們定義一些通用樣式蜈膨,放在一個樣式表里面屿笼,然后在各個組件都可以引用,或者作為全局樣式表翁巍,這樣肯定會比重復定義樣式表要更優(yōu)驴一,同樣其他文件(js、html等)都可以采用復用的方案灶壶。
  • 模塊化
    模塊化的思想在早些年就出現(xiàn)了:將一個復雜的程序依據(jù)一定的規(guī)則(規(guī)范)封裝成幾個塊(文件), 并進行組合在一起肝断,最流行的CommonJS, AMD, ES6、CMD規(guī)范驰凛,都是模塊化的方案胸懈,通過js來維護一個整體模塊,包括動態(tài)引入css/js/html恰响,或者動態(tài)生成
  • 后端復用
    后端優(yōu)化也是性能優(yōu)化的一部分趣钱,雖然一般情況下沒有前端優(yōu)化的效果那么直接,包括接口復用胚宦,UI模塊復用首有,通用工具API的復用等等。比如說我們再做數(shù)據(jù)傳輸间唉,可能某些頁面,或者某些頁面的多個部分利术,可以只使用一個接口來傳值呈野,然后再靠前端分配資源。若這些需要后端數(shù)據(jù)傳輸?shù)牟糠质菍儆谕活愘Y源印叁,后端可以復用接口被冒,當然也是一種優(yōu)化方案。

加載方式

加載方式是對用戶而言的轮蜕,提升用戶的體驗昨悼,文章后面會講到一些術語,比如跳出率跃洛,調(diào)查發(fā)現(xiàn)用戶在3到4秒時間之后若發(fā)現(xiàn)頁面加載無響應率触,就會選擇放棄瀏覽網(wǎng)頁,也就是我們說的“跳出”汇竭。所以加載方式是非常重要的優(yōu)化出發(fā)點葱蝗,加載方式分為三種:同步加載穴张、分級加載和按需加載。

  • 同步加載
    同步一般指頁面都加載完才給用戶看两曼,也就是用戶的瀏覽和頁面加載是同步的皂甘,這種加載方式可以用于TCP連接較少的頁面加載。
  • 分級加載
    同步加載和異步加載的結(jié)合悼凑,有了異步加載偿枕,我們可以選擇某一些關鍵模塊首先加載給用戶瀏覽,比如說視頻網(wǎng)站户辫,可以選擇關鍵視頻模塊首先加載渐夸,其余模塊進行異步加載,也就是在用戶開始瀏覽關鍵部分的時候進行加載其余模塊寸莫。當然捺萌,還有一種加載方式叫懶加載,用戶首先瀏覽首屏(第一眼看到的)膘茎,拖動頁面之后漸漸加載未加載的模塊桃纯,實現(xiàn)用戶看什么就加載什么,未進入瀏覽區(qū)域的就不加載披坏。
  • 按需加載
    用戶不觸發(fā)該功能就不加載态坦,
    用戶觸發(fā)該功能,就將該模塊的加載時間提前棒拂。

術語定義

介紹了優(yōu)化的出發(fā)點伞梯,再來了解一些術語可能會簡單一些。
首屏時間:加載到第一屏的功能點所消耗的時間帚屉,也就是用戶進來頁面第一眼看到的東西谜诫。
白屏時間:從進入頁面到head解析的時間,用戶看到白屏開始到頁面出現(xiàn)東西的時間攻旦。
可操時間:核心模塊的使用率和用戶感知喻旷,用戶可以操作核心模塊的等待時間。比如關鍵模塊點擊事件能否觸發(fā)牢屋。
連通率:用戶看到視頻或者聽到聲音的比例且预,這里的計算對象是用戶,比如100個人只有10個人看到視頻播放了烙无,連通率就是10%锋谐。

產(chǎn)品類術語有:一次訪問、多次訪問截酷、日活躍用戶涮拗、月活躍用戶、跳出率。
這里通俗地再解釋一次跳出率:用戶進入頁面因加載太慢放棄瀏覽的比例多搀。

解釋了這一些重要的術語歧蕉,我們可能大概知道這些術語之間的聯(lián)系了。比如說白屏時間和跳出率的聯(lián)系康铭,若用戶的白屏時間太久惯退,自然會降低用戶的體驗,造成跳出率升高从藤。

總結(jié)

這些知識只是性能優(yōu)化的冰山一角催跪,本文沒有介紹解決方案的具體做法。

  1. 我們首先要去了解瀏覽器的渲染原理夷野,從向服務器請求到頁面出現(xiàn)響應到底發(fā)生了一些什么
  2. 用戶訪問站點的時候會做些什么懊蒸,我們要站在用戶的角度去思考我們應該優(yōu)化哪些模塊,用什么方式優(yōu)化
  3. 可以了解業(yè)內(nèi)的通用優(yōu)化方案悯搔,比如雅虎軍規(guī)35條骑丸、Facebook和淘寶團隊的bigpipe方案 等等。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末妒貌,一起剝皮案震驚了整個濱河市通危,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌灌曙,老刑警劉巖菊碟,帶你破解...
    沈念sama閱讀 217,907評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異在刺,居然都是意外死亡逆害,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評論 3 395
  • 文/潘曉璐 我一進店門蚣驼,熙熙樓的掌柜王于貴愁眉苦臉地迎上來魄幕,“玉大人,你說我怎么就攤上這事颖杏〈吭桑” “怎么了?”我有些...
    開封第一講書人閱讀 164,298評論 0 354
  • 文/不壞的土叔 我叫張陵输玷,是天一觀的道長队丝。 經(jīng)常有香客問我靡馁,道長欲鹏,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,586評論 1 293
  • 正文 為了忘掉前任臭墨,我火速辦了婚禮赔嚎,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己尤误,他們只是感情好侠畔,可當我...
    茶點故事閱讀 67,633評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著损晤,像睡著了一般软棺。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上尤勋,一...
    開封第一講書人閱讀 51,488評論 1 302
  • 那天喘落,我揣著相機與錄音,去河邊找鬼最冰。 笑死瘦棋,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的暖哨。 我是一名探鬼主播赌朋,決...
    沈念sama閱讀 40,275評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼篇裁!你這毒婦竟也來了沛慢?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,176評論 0 276
  • 序言:老撾萬榮一對情侶失蹤茴恰,失蹤者是張志新(化名)和其女友劉穎颠焦,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體往枣,經(jīng)...
    沈念sama閱讀 45,619評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡伐庭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,819評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了分冈。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片圾另。...
    茶點故事閱讀 39,932評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖雕沉,靈堂內(nèi)的尸體忽然破棺而出集乔,到底是詐尸還是另有隱情,我是刑警寧澤坡椒,帶...
    沈念sama閱讀 35,655評論 5 346
  • 正文 年R本政府宣布扰路,位于F島的核電站,受9級特大地震影響倔叼,放射性物質(zhì)發(fā)生泄漏汗唱。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,265評論 3 329
  • 文/蒙蒙 一丈攒、第九天 我趴在偏房一處隱蔽的房頂上張望哩罪。 院中可真熱鬧授霸,春花似錦、人聲如沸际插。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽框弛。三九已至辛辨,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瑟枫,已是汗流浹背愉阎。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留力奋,地道東北人榜旦。 一個月前我還...
    沈念sama閱讀 48,095評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像景殷,于是被迫代替她去往敵國和親溅呢。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,884評論 2 354