欧美精品v日韩精品v国产精品_全免费a级毛片免费看不卡_91精品国产91热久久久久福利_成人毛片免费观看视频在线

React SSG - 也寫(xiě)個(gè) Demo 吧

來(lái)源:博客園

上次寫(xiě)了一個(gè) SSRDEMO,今天寫(xiě)個(gè)小 Demo來(lái)從頭實(shí)現(xiàn)一下 reactSSG,來(lái)理解下 SSG是如何實(shí)現(xiàn)的。

什么是 SSG

SSGStatic Site Generation靜態(tài)站點(diǎn)生成,是指將在構(gòu)建時(shí)就提前生成靜態(tài) HTML頁(yè)面,速度很快,一般用于以下場(chǎng)景:

SEO(搜索引擎優(yōu)化):由于部分搜索引擎對(duì) CSR內(nèi)容支持不佳,所以 SSG可以提升網(wǎng)站在搜索引擎結(jié)果中的排名。靜態(tài)站點(diǎn):比如博客、CMS系統(tǒng)輸出站點(diǎn)等,由于內(nèi)容以靜態(tài)內(nèi)容居多,都可以使用 SSG。如何實(shí)現(xiàn)

簡(jiǎn)單的 SSGSSR實(shí)現(xiàn)原理差不多,只是時(shí)機(jī)不同: SSR渲染 HTML的過(guò)程在服務(wù)端,而 SSG則在構(gòu)建時(shí)。渲染同樣是通過(guò)在 Node端導(dǎo)入要渲染的組件,然后調(diào)用 react-dom/server包中提供的 renderToString方法將該組件的渲染內(nèi)容輸出為 HTML保存。


(資料圖片僅供參考)

系統(tǒng)設(shè)計(jì)

下面使用 SSG實(shí)現(xiàn)一個(gè)簡(jiǎn)單的靜態(tài)博客系統(tǒng):

每篇博文都使用一個(gè) JSON文件來(lái)記錄其中的信息(為了簡(jiǎn)化沒(méi)有使用 markdown,可以理解為 markdown博文信息已提前轉(zhuǎn)換為 JSON文件)構(gòu)建時(shí)會(huì)將博文編譯為靜態(tài) HTML文件,并生成一個(gè)博文列表的 HTML文件通過(guò)靜態(tài)文件服務(wù)器啟動(dòng)即可展示博文組件設(shè)計(jì)

可以看出我們只需要兩個(gè)組件:

一個(gè) Post組件,用于接收博文信息展示博文一個(gè) List組件,用于接受博文列表展示博文清單

簡(jiǎn)單的實(shí)現(xiàn)一下:

import React from "react";export default ({    data}: {    data: {        title: string;        content: { title: string; content: string }[];    };}) => {    return (        

{data.title}

{data.content.map(({ title, content }) => (

{title}

{content}

))}
);};
import React from "react";export default ({ list }: { list: { title: string; key: string }[] }) => {    return (        
    {list.map(({ title, key }) => (
  • {title}
  • ))}
);};
構(gòu)建腳本

然后再來(lái)實(shí)現(xiàn)下構(gòu)建腳本,首先構(gòu)建腳本一樣需要支持 JSX的解析,然后構(gòu)建腳本讀取博文數(shù)據(jù)文件夾下的所有文件,將其依次解析為靜態(tài) HTML,并且再生成一份列表的 HTML。

代碼也非常簡(jiǎn)單:

import fs from "fs";import { renderToString } from "react-dom/server";import React from "react";import Post from "./ui/Post";import List from "./ui/List";// get all the files in postsconst posts = fs.readdirSync("posts");// make sure the dir existsif (!fs.existsSync("dist")) {    fs.mkdirSync("dist");}if (!fs.existsSync("dist/posts")) {    fs.mkdirSync("dist/posts");}posts.map(post => {    const postInfo = require("./posts/" + post);    const fileName = `dist/posts/${post.replace(".json", ".html")}`;    // make sure file exists    fs.writeFileSync(fileName, `
${renderToString()}
`);});fs.writeFileSync( "dist/index.html", `
${renderToString( ({ ...require("./posts/" + post), key: post.replace(".json", "") }))} /> )}
`);

首先通過(guò) readdirSync讀取博文信息目錄,這里只處理了單層,復(fù)雜點(diǎn)的需要遞歸處理下多層目錄結(jié)構(gòu)。然后將每篇博文通過(guò) renderToString渲染為靜態(tài) HTML并寫(xiě)入文件。最后再輸出列表對(duì)應(yīng)的 HTML文件即可。

通過(guò)該腳本可以通過(guò)以下的博文:

生成以下 HTML

靜態(tài)文件服務(wù)

HTML生成后,只需要啟動(dòng)靜態(tài)文件服務(wù)器,將靜態(tài) HTML丟過(guò)去即可,可以使用 nginx或者 serve包。

更多細(xì)節(jié)

上面只是一個(gè)最簡(jiǎn)單的例子,要實(shí)現(xiàn)一個(gè)完整的系統(tǒng)還需要考慮以下幾個(gè)方面:

樣式支持 - 在渲染靜態(tài)文件時(shí)添加上 link引入即可。hydrate- 本文并沒(méi)有實(shí)現(xiàn) hydrate,其實(shí)實(shí)現(xiàn)邏輯差不多,在靜態(tài)文件渲染時(shí)嵌入腳本,然后腳本在客戶(hù)端進(jìn)行 hydrate,不過(guò)一般的 SSG場(chǎng)景下動(dòng)態(tài)的內(nèi)容不多,所以如果沒(méi)有交互可以忽略。總結(jié)

React中的 SSG本質(zhì)也是通過(guò) renderToString來(lái)實(shí)現(xiàn),但是時(shí)機(jī)與 SSR不同,是在構(gòu)建時(shí)進(jìn)行。

最后

本文的 demo代碼放置在 React SSG Demo 中,可自行取閱。

關(guān)鍵詞:

推薦

直播更多》

關(guān)閉

資訊更多》

焦點(diǎn)

欧美精品v日韩精品v国产精品_全免费a级毛片免费看不卡_91精品国产91热久久久久福利_成人毛片免费观看视频在线

菠萝蜜视频在线观看一区| 亚洲国产成人av网| 欧洲精品在线观看| 久久丝袜美腿综合| 亚洲图片有声小说| eeuss鲁片一区二区三区在线看| 综合激情成人伊人| 91精品福利在线一区二区三区 | 国产精品福利一区| 美女mm1313爽爽久久久蜜臀| 久久久久久久久伊人| 色婷婷久久久综合中文字幕| 国产亚洲精品aa| 美女视频网站黄色亚洲| 国产欧美日韩精品在线| 欧美午夜电影在线播放| 国产精品乱人伦一区二区| 黄色小说综合网站| 亚洲天堂成人网| 精品理论电影在线| 午夜精品久久久久久久| 久久奇米777| 欧美日韩国产综合视频在线观看 | 日韩av一二三| 国产喷白浆一区二区三区| 欧美日韩视频不卡| 亚洲天堂网中文字| 国产91色综合久久免费分享| 亚洲一区在线视频| 久久久影视传媒| 精品午夜久久福利影院| 亚洲天堂免费在线观看视频| 欧美成人猛片aaaaaaa| 丝袜美腿亚洲综合| 国产精品私房写真福利视频| 日韩视频在线永久播放| 免费人成精品欧美精品| 国产精品久久福利| 精品捆绑美女sm三区| 麻豆国产精品一区二区三区| 亚洲视频免费看| 国产偷国产偷亚洲高清人白洁 | 日韩欧美亚洲国产精品字幕久久久| 亚洲大片免费看| 国产日产欧产精品推荐色| 91精品国产一区二区三区| 午夜久久久影院| 国产精品视频线看| 欧美精品一区二区三区蜜桃视频| 狠狠狠色丁香婷婷综合激情| 亚洲自拍偷拍网站| 椎名由奈av一区二区三区| 91亚洲大成网污www| 欧美二区在线观看| 蜜乳av一区二区三区| 一区二区三区视频在线看| 国产精品美女久久久久aⅴ | 亚洲欧美电影一区二区| 久久嫩草精品久久久精品一| 日韩亚洲欧美在线观看| 久久国产精品72免费观看| 亚洲一二三四在线观看| 亚洲人成电影网站色mp4| 国产天堂亚洲国产碰碰| www国产亚洲精品久久麻豆| 国产成人自拍在线| 欧美日韩精品是欧美日韩精品| 日日夜夜精品视频免费 | 一区二区三区国产豹纹内裤在线| 国产免费成人在线视频| 久久久综合网站| 成人综合日日夜夜| 91精品国产综合久久福利| 久久福利资源站| 91成人在线精品| 三级久久三级久久久| 亚洲精品久久久久久国产精华液| 日韩理论在线观看| 日本一区二区免费在线观看视频| 国产日韩精品一区| 久久新电视剧免费观看| 精品国产a毛片| yourporn久久国产精品| 欧美一区二区观看视频| 国产成人亚洲综合a∨猫咪| 欧美日韩国产免费一区二区| 久久99精品久久久久久久久久久久| 色素色在线综合| 久久精品国产亚洲a| 在线一区二区三区四区| 美腿丝袜亚洲综合| 在线观看日韩一区| 九九九久久久精品| 欧美日韩免费一区二区三区| 精品一区二区日韩| 欧美福利一区二区| 国产成人免费视| 精品伦理精品一区| 91亚洲精品久久久蜜桃网站| www日韩大片| 久久日一线二线三线suv| 国产日韩欧美制服另类| 国产欧美一区在线| 亚洲欧洲av色图| 伊人色综合久久天天| 午夜欧美在线一二页| 色偷偷88欧美精品久久久| 久久精品噜噜噜成人88aⅴ| 欧美三级一区二区| 粉嫩欧美一区二区三区高清影视| 日韩精品一区二| 久久亚洲欧美国产精品乐播| 国产精品色噜噜| 亚洲美女偷拍久久| 五月天视频一区| 在线欧美日韩国产| 国产高清无密码一区二区三区| 日韩精品在线一区二区| 久久亚洲精华国产精华液| 亚洲欧美在线观看| 亚洲午夜精品在线| 精品中文字幕一区二区| 日韩欧美中文字幕制服| 国产视频一区二区在线| 尤物视频一区二区| 一本色道久久综合精品竹菊| 国产麻豆成人精品| 久久久一区二区三区捆绑**| 中文字幕成人网| 午夜天堂影视香蕉久久| 欧美日韩国产首页| 91在线丨porny丨国产| 中文字幕一区二区三区四区不卡| 亚洲宅男天堂在线观看无病毒| 裸体健美xxxx欧美裸体表演| 日韩一区二区免费在线电影| 国产情人综合久久777777| 亚洲一区二区三区视频在线| 欧美在线免费播放| 99久久免费国产| 亚洲同性同志一二三专区| 性久久久久久久久| 国产成人av影院| 国产精品美女一区二区三区| 亚洲国产精品久久久男人的天堂| 国内成人免费视频| 国产亚洲精品资源在线26u| 亚洲美女视频在线| 国产在线精品国自产拍免费| 久久久久久夜精品精品免费| 亚洲精品免费视频| 国产精品影视在线观看| 国产精品视频免费| 婷婷综合五月天| 北条麻妃国产九九精品视频| 亚洲免费成人av| 欧美日韩一区二区三区在线看| 久久综合九色综合97婷婷女人| 亚洲线精品一区二区三区八戒| 欧美福利视频一区| 中文字幕av免费专区久久| 日本va欧美va精品| 久久久三级国产网站| 亚洲一区二区三区国产| 成人教育av在线| 一区二区三区毛片| 欧美一级高清片| 亚洲精品亚洲人成人网在线播放| 激情都市一区二区| 亚洲欧洲美洲综合色网| 欧美亚日韩国产aⅴ精品中极品| 久久久精品影视| 免费观看一级特黄欧美大片| 国产日韩成人精品| 在线观看不卡一区| 国产午夜精品一区二区三区视频 | 日韩在线a电影| 久久久久久久久久久久电影 | 久久免费美女视频| 婷婷国产v国产偷v亚洲高清| 99re热这里只有精品视频| 午夜一区二区三区视频| 精品国产成人在线影院| 亚洲r级在线视频| 久久久久国产成人精品亚洲午夜| 日韩avvvv在线播放| 国产日韩精品一区二区三区| 欧洲av一区二区嗯嗯嗯啊| 欧美国产综合一区二区| 激情综合网激情| 亚洲激情男女视频| 欧美va亚洲va| 天天操天天色综合| 中文字幕精品一区二区精品绿巨人 | 最新国产の精品合集bt伙计| 福利电影一区二区三区| 午夜av区久久| 中文字幕亚洲在| 日韩一区二区在线观看视频 | 五月天久久比比资源色|