React 服務(wù)端渲染與預(yù)渲染

1混狠、服務(wù)端渲染

仍是SPA

  • 路由同步

需要用到 react-router-config 這個(gè)庫原探,它可以根據(jù) route 匹配到對應(yīng)的組件曾棕,拿到當(dāng)前route對應(yīng)的組件是實(shí)現(xiàn)路由同步的關(guān)鍵因块,再通過組件的靜態(tài)API方法獲取接口數(shù)據(jù)

  • 狀態(tài)同步

主要是在服務(wù)端通過組件的靜態(tài)API方法獲取接口數(shù)據(jù)后創(chuàng)建store震贵,再通過 window.store= store 傳遞給前端

  • 交互同步

主要是要將前端的 js 文件附加在服務(wù)端渲染的模板 html 文件中

服務(wù)端渲染的應(yīng)用場景:一般只是對重要的頁面淹魄,如首頁才會(huì)做郁惜,可以提高首屏加載速度,利于SEO甲锡。其他頁面實(shí)際上仍是CSR

2兆蕉、預(yù)渲染

預(yù)渲染不像服務(wù)器渲染那樣即時(shí)編譯 HTML,它只在構(gòu)建時(shí)為了特定的路由生成特定的幾個(gè)靜態(tài)頁面缤沦,等于我們可以通過 Webpack 插件將一些特定頁面組件 build 時(shí)就編譯為 html 文件虎韵,直接以靜態(tài)資源的形式輸出給搜索引擎。

const PrerenderSPAPlugin = require('prerender-spa-plugin');
const path = require('path');

module.exports = (config, env) => {
  if (env === 'production') {
    config.plugins = config.plugins.concat([
      new PrerenderSPAPlugin({
        routes: ['/'缸废,'/home'],
        staticDir: path.join(__dirname, 'build'),
      }),
    ]);
  }

  return config;
};

1包蓝、SPA變?yōu)镸PA
2、必須使用 History 路由企量,而不能使用 Hash 路由测萎,所以對于沒有做預(yù)渲染的頁面往往需要服務(wù)器配置路由,如nginx 配置如下:

location /{
    index  index.html index.htm;
    if (!-e $request_filename) {
        rewrite ^/(.*) /index.html last;
        break;
    }
}

3、對于動(dòng)態(tài)路由,如 /detail/:id建丧,是不支持的,不過可以換成 query 路由腕唧,如/detail?id=
4、應(yīng)用場景比較有限瘾英,能想到的就是骨架屏應(yīng)用四苇,比如首頁,為了速度方咆,我們會(huì)用一些骨架屏組件,如果不做預(yù)渲染蟀架,則骨架屏組件會(huì)等整個(gè)js文件加載完畢才開始渲染瓣赂,體驗(yàn)不好。如果做了預(yù)渲染片拍,則當(dāng)html文件加載完畢時(shí)就會(huì)開始渲染了

參考

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末煌集,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子捌省,更是在濱河造成了極大的恐慌苫纤,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,183評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異卷拘,居然都是意外死亡喊废,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評論 3 399
  • 文/潘曉璐 我一進(jìn)店門栗弟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來污筷,“玉大人,你說我怎么就攤上這事乍赫“曛” “怎么了?”我有些...
    開封第一講書人閱讀 168,766評論 0 361
  • 文/不壞的土叔 我叫張陵雷厂,是天一觀的道長惋增。 經(jīng)常有香客問我,道長改鲫,這世上最難降的妖魔是什么诈皿? 我笑而不...
    開封第一講書人閱讀 59,854評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮钩杰,結(jié)果婚禮上纫塌,老公的妹妹穿的比我還像新娘。我一直安慰自己讲弄,他們只是感情好措左,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著避除,像睡著了一般怎披。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上瓶摆,一...
    開封第一講書人閱讀 52,457評論 1 311
  • 那天凉逛,我揣著相機(jī)與錄音,去河邊找鬼群井。 笑死状飞,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的书斜。 我是一名探鬼主播诬辈,決...
    沈念sama閱讀 40,999評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼荐吉!你這毒婦竟也來了焙糟?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,914評論 0 277
  • 序言:老撾萬榮一對情侶失蹤样屠,失蹤者是張志新(化名)和其女友劉穎穿撮,沒想到半個(gè)月后缺脉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡悦穿,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評論 3 342
  • 正文 我和宋清朗相戀三年攻礼,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片咧党。...
    茶點(diǎn)故事閱讀 40,675評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡秘蛔,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出傍衡,到底是詐尸還是另有隱情深员,我是刑警寧澤,帶...
    沈念sama閱讀 36,354評論 5 351
  • 正文 年R本政府宣布蛙埂,位于F島的核電站倦畅,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏绣的。R本人自食惡果不足惜叠赐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望屡江。 院中可真熱鬧芭概,春花似錦、人聲如沸惩嘉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽文黎。三九已至惹苗,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間耸峭,已是汗流浹背桩蓉。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留劳闹,地道東北人院究。 一個(gè)月前我還...
    沈念sama閱讀 49,091評論 3 378
  • 正文 我出身青樓,卻偏偏與公主長得像本涕,于是被迫代替她去往敵國和親儡首。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評論 2 360

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