前端項(xiàng)目架構(gòu)參考

在當(dāng)今這個(gè)唯快不破的互聯(lián)網(wǎng)大環(huán)境下抱究,項(xiàng)目從架構(gòu)的時(shí)候就要考慮性能是否最優(yōu)焕刮,怎么樣讓用戶體驗(yàn)更好

質(zhì)量相同的情況下邓馒,用戶體驗(yàn)好壞一般分兩種:

  • 初始渲染:首屏加載速度

  • 頁(yè)面跳轉(zhuǎn):頁(yè)面跳轉(zhuǎn)加載速度

一轿塔、大環(huán)境下的優(yōu)化

1.css樣式置頂特愿,優(yōu)化樣式減少不必要的重繪

1)樣式表放在網(wǎng)頁(yè)的head中,首先勾缭,這樣會(huì)給用戶加載速度快的感覺(jué)揍障,其次,因?yàn)闃邮奖頉Q定了網(wǎng)頁(yè)的繪制信息俩由,所以放在頭部可以最大話的避免重繪和重排
2)樣式表中盡量避免使用計(jì)算屬性和@import 如:calc毒嫡,因?yàn)橛?jì)算屬性不可避免造成重繪和重排
3)樣式表中盡量使用簡(jiǎn)寫如:

/*16進(jìn)制顏色*/
#000000
/*可以寫成*/
#000


margin-top:2px
margin-right:3px;
margin-bottom:4px;
margin-left:5px;

margin:2px 3px 4px 5px;

2.javascript腳本置底,優(yōu)化dom操作

由于javascript是阻塞加載幻梯,所以盡量把javascript放在網(wǎng)頁(yè)下邊兜畸,在首屏加載的時(shí)候盡量減少對(duì)dom的操作努释,因?yàn)檫@回引起頁(yè)面大量的重繪

3.減少http請(qǐng)求

可以通過(guò)合并靜態(tài)文件,使用圖標(biāo)字體咬摇,精靈圖伐蒂,合并接口等方式減少http請(qǐng)求次數(shù)

4.延時(shí)加載

可以把首屏顯示之外的文件使用延時(shí)加載,來(lái)提高首屏速度

5.避免請(qǐng)求空src

src值為空的時(shí)候肛鹏,依然會(huì)發(fā)送http請(qǐng)求

6.使用壓縮工具壓縮傳輸

gzip等

7.使用CDN加速

CDN通過(guò)尋找離請(qǐng)求最近的資源服務(wù)器來(lái)提高用戶的下載速度逸邦,合理使用CDN可以是網(wǎng)站加載速度倍增

8.使用緩存技術(shù)

在靜態(tài)資源配置的時(shí)候可以給承載資源加載鏈接(如:index.html)以強(qiáng)制不緩存,其余資源做強(qiáng)制緩存龄坪,靜態(tài)資源做打包的時(shí)候可以直接附加hash值昭雌,從而合理給頁(yè)面緩存,合理使用緩存可以使網(wǎng)站加載速度倍增

9.打包優(yōu)化

充分利用webpack等打包工具的打包功能健田,對(duì)代碼進(jìn)行拆包烛卧,壓縮,以及組件的按需導(dǎo)入

二妓局、代碼內(nèi)部?jī)?yōu)化

1.組件化

首先組件化代碼可以提高代碼重用率总放,其次組件化代碼能減少不必要的計(jì)算和更新提高頁(yè)面二次渲染性能

2.使用狀態(tài)管理工具

預(yù)估項(xiàng)目最終程度,如果項(xiàng)目達(dá)到一定程度使用狀態(tài)管理工具好爬,方便管理狀態(tài)局雄,方便各個(gè)組件之間狀態(tài)共享,減少不必要請(qǐng)求存炮,

3.框架使用優(yōu)化

優(yōu)化各個(gè)框架提供屬性和方法:比如減少refs使用炬搭,合理設(shè)置更新邏輯,避免不必要的重復(fù)渲染

4.請(qǐng)求優(yōu)化

合理優(yōu)化調(diào)用請(qǐng)求方式穆桂,減少不必要的維護(hù)和代碼量比如:

//比如get請(qǐng)求宫盔,每次調(diào)用需要添加 method:'get'
require({url:'/test',method:'get'})
/*可以替換一下,
 *使用一個(gè)方法來(lái)封裝一下享完,
 *直接省去了每個(gè)調(diào)用method:'get'這幾個(gè)字符
*/
function get(url){
    return require({url,method:'get'})
}


/*雖然這么寫看起來(lái)知識(shí)省掉了幾個(gè)字符灼芭,
 *但是如果請(qǐng)求多了還是可以減少不小的打包量的,
 *其次請(qǐng)求后還需要數(shù)據(jù)處理般又,
 *如:
 */
 require({url:'/test',method:'get'}).then(data=>data).catch(err=>err)


/*如果我們?cè)谂浜蠣顟B(tài)管理彼绷,
 *那么我們可以節(jié)約的代碼已經(jīng)非常可觀了
 */
function get({url,commit,type,params}){
    require({url:'/test',method:'get'})
        .then(data=>{
            commit(type,{data})
        })
        .catch(err=>{
            commit(type,err)
        })
}


action({commit}){
    get({url:'/test',commit,type})
}

5.路由優(yōu)化

1)可以合理安排使用嵌套路由茴迁,嵌套路由可以減少不必要的重復(fù)加載寄悯,現(xiàn)實(shí)局部更新
2)把一些權(quán)限有關(guān)的組件可以進(jìn)行封裝,通過(guò)路由來(lái)實(shí)現(xiàn)堕义,減少不必要的判斷和加載

<!--
比如列表:操作 列需要固定權(quán)限才可以使用
-->
<table>

    <tr>

        <td>姓名</td>
 
 
        <td>賬號(hào)</td>
 
 
        <td>出生日期</td>
 
 
        <td>愛好</td>
 
 
        <td>操作</td>

    </tr>

</table>
 
 
<!--
可以提取共有表格
-->
<table>

    <tr>

        <td>姓名</td>
 
        <td>賬號(hào)</td>
 
        <td>出生日期</td>
 
        <td>愛好</td>
 
        <child/>
 
    </tr>
 
</table>
 
<!--
在有權(quán)限的路由調(diào)用的時(shí)候傳入操作列
-->
<MyUserTable>

    <td>操作</td>

</MyUserTable>
 
<!--
不同的前端框架有不同的組件使用模式热某,
但原理是相同的,我們通過(guò)這種方式,
可以把操作列和操作相關(guān)的代碼拿出來(lái)昔馋,
這樣沒(méi)有對(duì)應(yīng)權(quán)限的用戶,
就不需要加載這部分永遠(yuǎn)不會(huì)用到的代碼了
-->
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末糖耸,一起剝皮案震驚了整個(gè)濱河市秘遏,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌嘉竟,老刑警劉巖邦危,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異舍扰,居然都是意外死亡倦蚪,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門边苹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)陵且,“玉大人,你說(shuō)我怎么就攤上這事个束∧焦海” “怎么了?”我有些...
    開封第一講書人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵茬底,是天一觀的道長(zhǎng)沪悲。 經(jīng)常有香客問(wèn)我,道長(zhǎng)阱表,這世上最難降的妖魔是什么殿如? 我笑而不...
    開封第一講書人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮最爬,結(jié)果婚禮上涉馁,老公的妹妹穿的比我還像新娘。我一直安慰自己烂叔,他們只是感情好谨胞,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蒜鸡,像睡著了一般胯努。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上逢防,一...
    開封第一講書人閱讀 51,708評(píng)論 1 305
  • 那天叶沛,我揣著相機(jī)與錄音,去河邊找鬼忘朝。 笑死灰署,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播溉箕,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼晦墙,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了肴茄?” 一聲冷哼從身側(cè)響起晌畅,我...
    開封第一講書人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎寡痰,沒(méi)想到半個(gè)月后抗楔,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡拦坠,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年连躏,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了懒棉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片掠剑。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖吹由,靈堂內(nèi)的尸體忽然破棺而出疲迂,到底是詐尸還是另有隱情才顿,我是刑警寧澤,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布尤蒿,位于F島的核電站郑气,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏腰池。R本人自食惡果不足惜尾组,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望示弓。 院中可真熱鬧讳侨,春花似錦、人聲如沸奏属。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)囱皿。三九已至勇婴,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間嘱腥,已是汗流浹背耕渴。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留齿兔,地道東北人橱脸。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓础米,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親添诉。 傳聞我的和親對(duì)象是個(gè)殘疾皇子屁桑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Yahoo!的Exceptional Performance團(tuán)隊(duì)為改善Web性能帶來(lái)最佳實(shí)踐。他們?yōu)榇诉M(jìn)行了一系列...
    拉風(fēng)的老衲閱讀 1,849評(píng)論 0 1
  • 網(wǎng)站優(yōu)化離不開前后端的互相協(xié)作吻商,但是對(duì)于前端工程師來(lái)說(shuō)掏颊,在保證后端技術(shù)方案不變時(shí),能不能只利用前端技術(shù)來(lái)優(yōu)化網(wǎng)站呢...
    留七七閱讀 6,327評(píng)論 0 31
  • yahoo軍規(guī)一共分8個(gè)部分共35條: 內(nèi)容部分: 1. 盡量減少HTTP請(qǐng)求數(shù) 80%的終端用戶響應(yīng)時(shí)間都花在了...
    revert閱讀 4,729評(píng)論 0 2
  • 1艾帐、盡量減少HTTP請(qǐng)求次數(shù) 終端用戶響應(yīng)的時(shí)間中,有80%用于下載各項(xiàng)內(nèi)容盆偿,這部分時(shí)間包括下載頁(yè)面中的圖像柒爸、樣式...
    兔子不打地鼠打代碼閱讀 530評(píng)論 0 1
  • 2017年,8月22日事扭。 很多天沒(méi)有回家了捎稚,在自己的床上睡得格外舒服。本來(lái)也是想要睡個(gè)懶覺(jué)的求橄。但是七點(diǎn)不到還是醒來(lái)...
    藍(lán)朵格格閱讀 248評(píng)論 0 1