簡單談?wù)劮?wù)器渲染

服務(wù)器端渲染主要有兩個(gè)優(yōu)勢(shì)猪勇,一是加快首屏渲染時(shí)間踱承,二是有利于SEO排作。本文將通過圖文簡要分析一下服務(wù)器渲染如何減少首屏渲染時(shí)間。

我們來看看服務(wù)器端與客戶端渲染的流程圖:

Screen Shot 2017-04-13 at 21.57.20.png
Screen Shot 2017-04-13 at 21.57.29.png
Screen Shot 2017-04-13 at 21.57.36.png

圖一為客戶端渲染流程圖油吭,圖二击蹲,三為服務(wù)器端渲染流程圖。

兩個(gè)渲染圖都可以分為兩個(gè)階段:
一:客戶端發(fā)送請(qǐng)求婉宰,服務(wù)器端返回html文件歌豺。
二:客戶端請(qǐng)求js文件,下載完成后本地建立react實(shí)例心包。

盡管服務(wù)器渲染第一階段的流程圖很長类咧,但是因?yàn)榉?wù)器渲染速度很快,因此實(shí)際耗時(shí)與客戶端渲染幾乎相同蟹腾。

第一階段結(jié)束時(shí)痕惋,服務(wù)器端返回渲染結(jié)果,用戶即可看到首屏娃殖。而對(duì)于客戶端渲染值戳,需要等待一次腳本下載時(shí)間,以及在客戶端的渲染時(shí)間炉爆。由于客戶端的硬件以及網(wǎng)絡(luò)條件的差異堕虹,這兩段時(shí)間開銷可能十分顯著。

客戶渲染與服務(wù)器渲染第二階段基本一致芬首。所不同的是赴捞,服務(wù)器渲染流程中,在客戶端生成vdom后郁稍,并不會(huì)重新渲染赦政,而是比較現(xiàn)有dom的checksum來決定是否重新渲染。

實(shí)戰(zhàn)中的服務(wù)器端渲染需要配置很多問題耀怜,比如說:

  • 如何保持前后端數(shù)據(jù)一致
  • 如何在后端進(jìn)行路由恢着,且和前端共享路由代碼
  • 服務(wù)器端如何打包靜態(tài)資源

前后端數(shù)據(jù)一致

我們假設(shè)使用redux作為store。在服務(wù)器渲染時(shí)财破,將store傳入渲染函數(shù)然评,隨后將store作為全局變量插入到返回的html文件中。

在客戶端文件中狈究,使用該全局變量作為store的初始值。代碼片段如下:

//server side
var root = renderToString(
   <Provider store={store}>
     <RouterContext {..._renderProps}/>
   </Provider>
)
ctx.render('home', {
   root,
   state: store.getState()
})

//view template
script.
      window.REDUX_STATE = !{JSON.stringify(state)}

//client side
const store = configureStore(window.REDUX_STATE);

路由控制

首先將具體的路由提取到單一文件中。

const routes = (
  <Route path="/" component={NavBar}>
    <IndexRoute component={App} />
    <Route path="/Person" component={Person} />
    <Route path="/Profile" component={Profile} />
  </Route>
)

隨后在客戶端與服務(wù)器端:

//客戶端
<Provider store={store}>
  <Router history={browserHistory}>
     {routes}
  </Router>
</Provider>

//服務(wù)器
match({routes, location: ctx.url}, (error, redirectLocation, renderProps) => {
  _renderProps = renderProps
});
<Provider store={store}>
   <RouterContext {..._renderProps}/>
</Provider>

這里match抖锥,RouterContext都是react-router為了服務(wù)器渲染準(zhǔn)備的函數(shù)亿眠。

服務(wù)器端如何打包靜態(tài)資源

這個(gè)沒什么經(jīng)驗(yàn)。

大家可以看看這篇文章http://www.reibang.com/p/0ecd727107bb磅废。 我的這篇文章主要是根據(jù)ChikaraChan的文章寫的學(xué)習(xí)筆記纳像。

ChikaraChan為服務(wù)器端渲染寫了一個(gè)腳手架。除了我剛剛提到的幾個(gè)問題拯勉,他還考慮開發(fā)項(xiàng)目的其他很多問題竟趾。

參考文章

  1. 教你如何搭建一個(gè)超完美的服務(wù)端渲染開發(fā)環(huán)境
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市宫峦,隨后出現(xiàn)的幾起案子岔帽,更是在濱河造成了極大的恐慌,老刑警劉巖导绷,帶你破解...
    沈念sama閱讀 206,482評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件犀勒,死亡現(xiàn)場離奇詭異,居然都是意外死亡妥曲,警方通過查閱死者的電腦和手機(jī)贾费,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來檐盟,“玉大人褂萧,你說我怎么就攤上這事】” “怎么了导犹?”我有些...
    開封第一講書人閱讀 152,762評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長陌宿。 經(jīng)常有香客問我锡足,道長,這世上最難降的妖魔是什么壳坪? 我笑而不...
    開封第一講書人閱讀 55,273評(píng)論 1 279
  • 正文 為了忘掉前任舶得,我火速辦了婚禮,結(jié)果婚禮上爽蝴,老公的妹妹穿的比我還像新娘沐批。我一直安慰自己,他們只是感情好蝎亚,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評(píng)論 5 373
  • 文/花漫 我一把揭開白布九孩。 她就那樣靜靜地躺著,像睡著了一般发框。 火紅的嫁衣襯著肌膚如雪躺彬。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,046評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音宪拥,去河邊找鬼仿野。 笑死,一個(gè)胖子當(dāng)著我的面吹牛她君,可吹牛的內(nèi)容都是我干的脚作。 我是一名探鬼主播,決...
    沈念sama閱讀 38,351評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼缔刹,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼球涛!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起校镐,我...
    開封第一講書人閱讀 36,988評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤亿扁,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后灭翔,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體魏烫,經(jīng)...
    沈念sama閱讀 43,476評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評(píng)論 2 324
  • 正文 我和宋清朗相戀三年肝箱,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了哄褒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,064評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡煌张,死狀恐怖呐赡,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情骏融,我是刑警寧澤链嘀,帶...
    沈念sama閱讀 33,712評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站档玻,受9級(jí)特大地震影響怀泊,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜误趴,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評(píng)論 3 307
  • 文/蒙蒙 一霹琼、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧凉当,春花似錦枣申、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至楼雹,卻和暖如春模孩,著一層夾襖步出監(jiān)牢的瞬間尖阔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評(píng)論 1 262
  • 我被黑心中介騙來泰國打工榨咐, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留诺祸,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,511評(píng)論 2 354
  • 正文 我出身青樓祭芦,卻偏偏與公主長得像,于是被迫代替她去往敵國和親憔鬼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子龟劲,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評(píng)論 2 345

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