javascript - node.js服務端渲染解疑
問題描述
關于服務端渲染我也看過一些相應的文章,貌似就是將一些框架在node端執行初始化。但是我在想,一般前端框架肯定是要涉及dom的,但是服務端肯定是沒dom操作的。我想問的是那:1.所謂的服務端渲染是解決了什么問題?2.seo的問題是如何被解決了?3.spa應用的首屏性能低目前有一些什么解決策略?
問題解答
回答1:對于 react 的服務端渲染,簡單說說我的理解:
最大的應該是解決 seo 的問題,其次在于加快 client 渲染的速度。
server-side-rendering(SSR) 簡單來說就是調用了 ReactDOM.renderToString 這個方法,在服務器端的一個 js 上下文對組件進行渲染,然后返回 html 的標簽,這樣,當 client 端 react 跑的時候,通過 react 的虛擬 dom 通過對比 react-id 進行增量更新,也就是如果某個 dom 上面 client 沒有啥更新的話,就直接拿 server 的結果,所以說在一定程度上加速了 client 的渲染速度。
其次就是 seo 因為 server 直接返回了 html 的標簽,所以即使是爬蟲,也會返回真正的有 seo 的標簽。這對一些門戶網站非常有用。這樣搜索引擎的爬蟲就能爬到網站的關鍵信息,對網站排名有所幫助。
SSR 性能的話,一般的解決方法貌似都是通過 cache,github 上面有一些項目,例如electrode-react-ssr-cachingreact-ssr-optimization 這些項目都是通過 cache 對 SSR 進行優化,本質上都是通過對比 props,進行 cache 加快下一次渲染。
相關文章:
1. PHP類中的$this2. python - Django Admin創建不關聯任何model的自定義頁面3. javascript - h5分享鏈接到qq或者微信時有一個縮略圖還有一些說明文字,這個要怎么去修改里面的圖片和內容?4. javascript 如何下載一個excel文件 ?5. 誰有mysql5.7安裝的詳細教程6. mysql - 看這條sql有可能被注入嗎7. python - Django操作數據庫遇到問題,無法查詢更新后的數據8. 請問是對象還是數組9. android - 第三方App調用高德地圖,總是直接進入到導航頁面,有沒有辦法進入首頁?10. python2.7 - Python安裝模組不成功
