Heim Web-Frontend js-Tutorial Erläutern Sie ausführlich die Probleme im Zusammenhang mit der Implementierung des React-Server-Renderings

Erläutern Sie ausführlich die Probleme im Zusammenhang mit der Implementierung des React-Server-Renderings

Jun 09, 2018 pm 02:14 PM
react

In diesem Artikel wird hauptsächlich die detaillierte Implementierung des React-Server-Renderings von Grund auf vorgestellt. Jetzt werde ich es mit Ihnen teilen und Ihnen eine Referenz geben.

Vorwort

Als ich kürzlich Koa schrieb, dachte ich: Wenn ein Teil meines Codes API bereitstellt und ein Teil des Codes SSR unterstützt, wie soll ich es dann schreiben? (Wenn Sie es nicht in zwei Dienste aufteilen möchten)
Und ich habe in den Projekten, die ich kürzlich geschrieben habe, wie Nuxt, auch etwas serverseitiges Rendering verwendet, und ich habe auch an nächsten Projekten gearbeitet Dass die Entwicklungserfahrung sehr freundlich ist, aber freundlich ist immer noch freundlich. Wie wird es konkret umgesetzt?

Im Einklang mit einer wahrheitssuchenden und pragmatischen Einstellung habe ich React als Forschungsobjekt gewählt (hauptsächlich, weil Vue etwas zu viel geschrieben wurde, was ekelhaft ist. Dann werde ich einfach einen React-Server schreiben). Side-Rendering-Demo zu minimalen Kosten

Verwendeter Technologie-Stack

react 16 + webpack3 + koa2

Sehen Sie sich an, wie es serverseitiges Rendering implementiert , Auf geht's!

Warum serverseitiges Rendering verwenden

Vorteile

Es sind nichts weiter als zwei Punkte

  1. SEO-freundlich

  2. Beschleunigen Sie das Rendern des ersten Bildschirms und reduzieren Sie die Zeit auf dem weißen Bildschirm

Die Frage ist also Was ist SEO?

Eine Einführung ist, dass die meisten Websites, die wir jetzt erstellen, SPA-Websites sind. Alle Seiten und Daten stammen von Ajax Finden Sie, dass sie alle leer sind? Glauben Sie also, dass Gewicht und Wirkung der Einbeziehung Ihrer Website gut oder schlecht sind?

Der Kern unserer SEO-Optimierung wird auch im folgenden Inhalt beschrieben:

Das Folgende ist der entscheidende Punkt!

Lassen Sie den Server den HTML-Code mit Inhalt an uns zurücksenden. Wenn das Ereignis eintritt, rendert der Browser ihn erneut zum Mounten.

Erstellen Sie eine Koa-Umgebung.

Neu Ein ssr-Projekt und initialisieren Sie npm im Projekt

mkdir ssr && cd ssr
npm init
Nach dem Login kopieren

Im folgenden Code verwenden wir Syntax wie import jsx, die von der Knotenumgebung nicht unterstützt wird, daher müssen wir babel konfigurieren

um im aktuellen Projekt eine neue Datei app.js und index.js zu erstellen, dann

babels Eingang, index.js-Code lautet wie folgt

require('babel-core/register')()

require('babel-polyfill')
require('./app')
Nach dem Login kopieren

der Eingang unseres Projekts, Der app.js-Code lautet wie folgt:

import Koa from 'koa'
const app = new Koa()

// response
app.use((ctx) => {
 ctx.body = 'Hello Koa'
})

app.listen(3000)
console.log("系统启动,端口:3000")
Nach dem Login kopieren

root Erstellen Sie eine neue .babelrc-Datei im Verzeichnis

mit dem Inhalt:

{
 "presets": ["react", "env"]
}
Nach dem Login kopieren

Installieren Sie die oben erforderlichen Abhängigkeiten

npm install babel-core babel-polyfill babel-preset-env babel-preset-react nodemon --save-dev
npm i koa --save
Nach dem Login kopieren

Konfigurieren Sie das Startskript

package.json

"scripts": {
 "dev": "nodemon index.js",
}
Nach dem Login kopieren

Hier führen Sie npm run dev aus und öffnen localhost:3000

Sie sehen Hallo Koa

Ist es sehr einfach, einen Dienst zu starten

React installieren

cnpm install react react-dom --save
Nach dem Login kopieren

Erstellen Sie einen neuen App-Ordner im Stammverzeichnis und erstellen Sie eine neue main.js im Ordner

Der main.js-Code lautet wie folgt

import React from 'react'

export default class Home extends React.Component {
 render () {
  return <p>hello world</p>
 }
}
Nach dem Login kopieren

Server.js vor der Änderung

import Koa from &#39;koa&#39;
import React from &#39;react&#39;
import { renderToString } from &#39;react-dom/server&#39;
import App from &#39;./app/main&#39;

const app = new Koa()

// response
app.use(ctx => {
 let str = renderToString(<App />)

 ctx.body = str
})

app.listen(3000)

console.log(&#39;系统启动,端口:8080&#39;)
Nach dem Login kopieren

Zu diesem Zeitpunkt führt npm dev aus

Sie werden Hallo sehen Welt erscheint auf dem Bildschirm

Chrome-Entwickler öffnen Das Tool prüft unsere Anfrage:

Unsere einfachste Reaktionskomponente wird str und übergeben

Hier verwenden wir eine Methode:

renderToString – rendert die Komponente tatsächlich in einen String

Bisher haben wir der Komponente keine Ereignisse und andere interaktive Verhaltensweisen hinzugefügt

Ändern Sie den Haupt-.js-Code

import React from &#39;react&#39;

export default class Home extends React.Component {
 render () {
  return <p onClick={() => window.alert(123)}>hello world</p>
 }
}
Nach dem Login kopieren

Aktualisieren Sie unsere Seite erneut, hey, ist das nutzlos?

Das liegt daran, dass das Backend Komponenten nur in eine Zeichenfolge mit Ereignisbindung rendern kann andere Dinge müssen auf der Browserseite ausgeführt werden
Wie binden wir also das Ereignis?

Dann werden Sie bestimmt vermuten, dass, da der Server eine HTML-Zeichenfolge rendert, die Möglichkeit zum Mounten des Ereignisses darin besteht, es im Browser erneut zu rendern

Einfach machen, machen, machen

Webpack konfigurieren

Erstellen Sie eine neue webpack.config.js im Stammverzeichnis

Das Folgende ist der Inhalt von webpack.config.js:

var path = require(&#39;path&#39;)
var webpack = require(&#39;webpack&#39;)

module.exports = {
 entry: {
  main: &#39;./app/index.js&#39;
 },
 output: {
  filename: &#39;[name].js&#39;,
  path: path.join(__dirname, &#39;public&#39;),
  publicPath: &#39;/&#39;
 },
 resolve: {
  extensions: [&#39;.js&#39;, &#39;.jsx&#39;]
 },
 module: {
  loaders: [
   {test: /\.jsx?$/,
    loaders: [&#39;babel-loader&#39;],
   }
  ]
 }
}
Nach dem Login kopieren

Die obige Konfiguration legt den Eintrag in der Datei app/index.js fest

Dann erstellen wir einen

Das Folgende ist der Code von app/index.js:

import Demo from &#39;./main&#39;
import ReactDOM from &#39;react-dom&#39;
import React from &#39;react&#39;
ReactDOM.render(<Demo />, document.getElementById(&#39;root&#39;))
Nach dem Login kopieren

Da beim Rendern des Browsers die Root-Komponente auf einem bestimmten Dom-Knoten gemountet werden muss, legen wir einen Eingang für unseren Reaktionscode fest.

Zu diesem Zeitpunkt liegt ein Problem vor, das heißt, die Umgebung des Dokumentobjektknotens ist nicht vorhanden Wenn es nicht existiert, wie kann man es lösen?

Existiert nicht? Wenn es nicht existiert, brauche ich es nicht. Der Kern von SSR besteht darin, bestimmte HTML-Inhalte in der angeforderten URL zurückzugeben. Ereignisse oder ähnliches sind mir egal, also gebe ich einfach die Stammkomponente zurück to renderToString

Ändern wir unseren Servicecode, um das Server-Rendering zu unterstützen

Fügen Sie einige Abhängigkeiten hinzu

cnpm i --save koa-static koa-views ejs
Nach dem Login kopieren

    koa-static: Mitten in der Verarbeitung statischer Dateien koa-views: Middleware zum Konfigurieren von Vorlagen
  1. ejs: eine Template-Engine
  2. Ändern Sie den Code des Servers. js
  3. import Koa from &#39;koa&#39;
    import React from &#39;react&#39;
    import { renderToString } from &#39;react-dom/server&#39;
    import views from &#39;koa-views&#39;
    import path from &#39;path&#39;
    
    import Demo from &#39;./app/main&#39;
    const app = new Koa()
    // 将/public文件夹设置为静态路径
    app.use(require(&#39;koa-static&#39;)(__dirname + &#39;/public&#39;))
    // 将ejs设置为我们的模板引擎
    app.use(views(path.resolve(__dirname, &#39;./views&#39;), { map: { html: &#39;ejs&#39; } }))
    
    // response
    app.use(async ctx => {
     let str = renderToString(<Demo />)
     await ctx.render(&#39;index&#39;, {
      root: str
     })
    })
    
    app.listen(3000)
    
    console.log(&#39;系统启动,端口:8080&#39;)
    Nach dem Login kopieren

    Erstellen Sie unten unsere Rendering-Vorlage

  4. Erstellen Sie einen Ansichtsordner

Erstellen Sie darin eine neue index.html:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <base href="/client" rel="external nofollow" >
</head>
<body>
  <p id="root"><%- root %></p>
  <script src="/main.js"></script>
</body>
</html>
Nach dem Login kopieren

Sie können einige Variablen einfügen in diesem HTML, wie zum Beispiel diesem <%- root %>, wo später das renderToString-Ergebnis platziert wird

/main.js ist der von React erstellte Code

Lassen Sie uns testen unseren Code direkt

1. In package.json

新增:

 "scripts": {
  "dev": "nodemon index.js",
  "build": "webpack"
 },
Nach dem Login kopieren

2. 运行 npm run build, 构建出我们的react代码

3. npm run dev

点击一下代码,是不是会 alert(123)

 tada 撒花,恭喜你,一个最简单服务器渲染就已经完成

到这里核心的思想就都已经讲完了,总结来说就下面三点:

  1. 起一个node服务

  2. 把react 根组件 renderToString渲染成字符串一起返回前端

  3. 前端再重新render一次

原理就是这么简单

但是具体开发的时候还会有各种各样的需求,比如:

  1. 不可能我每次改完代码都重新构建看效果吧 => 需要 实时构建

  2. create-react-app 都是热更新,你还要刷新是不是太蠢了 => 需要支持热更新

  3. 其他一些配套的周边,如: react-router, redux 或者mobx怎么支持呢 => 需要完善的生态

.etc

这些问题都是用完 官方脚手架之后就回不去了的,所以更多的配置可以参考下面的repo(是一个工具链完善的最小实现),欢迎提PR

GitHub - ws456999/koa-react-ssr-starter: to understand && to explain how react ssr works

目前你可以在里面找到 react + react-router + mobx + postcss + 热更新的配置,除了react-router的配置有些差别,其他都跟client端差别不大

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在vue中如何实现页面跳转后返回原页面初始位置

使用vue-router如何设置每个页面的title方法

如何解决Vue.js显示数据的时,页面闪现

Das obige ist der detaillierte Inhalt vonErläutern Sie ausführlich die Probleme im Zusammenhang mit der Implementierung des React-Server-Renderings. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So erstellen Sie eine Echtzeit-Chat-App mit React und WebSocket So erstellen Sie eine Echtzeit-Chat-App mit React und WebSocket Sep 26, 2023 pm 07:46 PM

So erstellen Sie eine Echtzeit-Chat-Anwendung mit React und WebSocket Einführung: Mit der rasanten Entwicklung des Internets hat die Echtzeitkommunikation immer mehr Aufmerksamkeit auf sich gezogen. Live-Chat-Apps sind aus dem modernen Sozial- und Arbeitsleben nicht mehr wegzudenken. In diesem Artikel wird erläutert, wie Sie mit React und WebSocket eine einfache Echtzeit-Chat-Anwendung erstellen, und es werden spezifische Codebeispiele bereitgestellt. 1. Technische Vorbereitung Bevor wir mit der Erstellung einer Echtzeit-Chat-Anwendung beginnen, müssen wir die folgenden Technologien und Tools vorbereiten: React: eine zum Erstellen

Leitfaden zur React-Front-End- und Back-End-Trennung: So erreichen Sie die Entkopplung und unabhängige Bereitstellung von Front-End und Back-End Leitfaden zur React-Front-End- und Back-End-Trennung: So erreichen Sie die Entkopplung und unabhängige Bereitstellung von Front-End und Back-End Sep 28, 2023 am 10:48 AM

React-Leitfaden zur Front-End- und Back-End-Trennung: So erreichen Sie die Front-End- und Back-End-Entkopplung und die unabhängige Bereitstellung. Es sind spezifische Codebeispiele erforderlich. In der heutigen Webentwicklungsumgebung ist die Front-End- und Back-End-Trennung zu einem Trend geworden. Durch die Trennung von Front-End- und Back-End-Code kann die Entwicklungsarbeit flexibler und effizienter gestaltet und die Zusammenarbeit im Team erleichtert werden. In diesem Artikel wird erläutert, wie Sie mithilfe von React eine Front-End- und Back-End-Trennung erreichen und so die Ziele der Entkopplung und unabhängigen Bereitstellung erreichen. Zuerst müssen wir verstehen, was Front-End- und Back-End-Trennung ist. Im traditionellen Webentwicklungsmodell sind Front-End und Back-End gekoppelt

So erstellen Sie einfache und benutzerfreundliche Webanwendungen mit React und Flask So erstellen Sie einfache und benutzerfreundliche Webanwendungen mit React und Flask Sep 27, 2023 am 11:09 AM

So erstellen Sie mit React und Flask einfache und benutzerfreundliche Webanwendungen. Einführung: Mit der Entwicklung des Internets werden die Anforderungen an Webanwendungen immer vielfältiger und komplexer. Um den Anforderungen der Benutzer an Benutzerfreundlichkeit und Leistung gerecht zu werden, wird es immer wichtiger, moderne Technologie-Stacks zum Aufbau von Netzwerkanwendungen zu verwenden. React und Flask sind zwei sehr beliebte Frameworks für die Front-End- und Back-End-Entwicklung, und sie arbeiten gut zusammen, um einfache und benutzerfreundliche Webanwendungen zu erstellen. In diesem Artikel erfahren Sie, wie Sie React und Flask nutzen

So erstellen Sie eine zuverlässige Messaging-App mit React und RabbitMQ So erstellen Sie eine zuverlässige Messaging-App mit React und RabbitMQ Sep 28, 2023 pm 08:24 PM

So erstellen Sie eine zuverlässige Messaging-Anwendung mit React und RabbitMQ Einführung: Moderne Anwendungen müssen zuverlässiges Messaging unterstützen, um Funktionen wie Echtzeitaktualisierungen und Datensynchronisierung zu erreichen. React ist eine beliebte JavaScript-Bibliothek zum Erstellen von Benutzeroberflächen, während RabbitMQ eine zuverlässige Messaging-Middleware ist. In diesem Artikel wird erläutert, wie Sie React und RabbitMQ kombinieren, um eine zuverlässige Messaging-Anwendung zu erstellen, und es werden spezifische Codebeispiele bereitgestellt. RabbitMQ-Übersicht:

React Router-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung React Router-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung Sep 29, 2023 pm 05:45 PM

ReactRouter-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung Mit der Popularität von Single-Page-Anwendungen ist das Front-End-Routing zu einem wichtigen Bestandteil geworden, der nicht ignoriert werden kann. Als beliebteste Routing-Bibliothek im React-Ökosystem bietet ReactRouter umfangreiche Funktionen und benutzerfreundliche APIs, wodurch die Implementierung des Front-End-Routings sehr einfach und flexibel ist. In diesem Artikel wird die Verwendung von ReactRouter vorgestellt und einige spezifische Codebeispiele bereitgestellt. Um ReactRouter zuerst zu installieren, benötigen wir

So erstellen Sie eine schnelle Datenanalyseanwendung mit React und Google BigQuery So erstellen Sie eine schnelle Datenanalyseanwendung mit React und Google BigQuery Sep 26, 2023 pm 06:12 PM

So verwenden Sie React und Google BigQuery zum Erstellen schneller Datenanalyseanwendungen. Einführung: Im heutigen Zeitalter der Informationsexplosion ist die Datenanalyse zu einem unverzichtbaren Bindeglied in verschiedenen Branchen geworden. Unter anderem ist die Entwicklung schneller und effizienter Datenanalyseanwendungen für viele Unternehmen und Einzelpersonen zum Ziel geworden. In diesem Artikel wird erläutert, wie Sie mit React und Google BigQuery eine schnelle Datenanalyseanwendung erstellen, und es werden detaillierte Codebeispiele bereitgestellt. 1. Übersicht React ist ein Werkzeug zum Erstellen

So verpacken und implementieren Sie Front-End-Anwendungen mit React und Docker So verpacken und implementieren Sie Front-End-Anwendungen mit React und Docker Sep 26, 2023 pm 03:14 PM

So verwenden Sie React und Docker zum Verpacken und Bereitstellen von Front-End-Anwendungen. Das Packen und Bereitstellen von Front-End-Anwendungen ist ein sehr wichtiger Teil der Projektentwicklung. Mit der rasanten Entwicklung moderner Frontend-Frameworks ist React für viele Frontend-Entwickler zur ersten Wahl geworden. Als Containerisierungslösung kann Docker den Anwendungsbereitstellungsprozess erheblich vereinfachen. In diesem Artikel wird erläutert, wie Sie mit React und Docker Front-End-Anwendungen packen und bereitstellen, und es werden spezifische Codebeispiele bereitgestellt. 1. Vorbereitung Bevor wir beginnen, müssen wir die Installation durchführen

So erstellen Sie Echtzeit-Datenverarbeitungsanwendungen mit React und Apache Kafka So erstellen Sie Echtzeit-Datenverarbeitungsanwendungen mit React und Apache Kafka Sep 27, 2023 pm 02:25 PM

So verwenden Sie React und Apache Kafka zum Erstellen von Echtzeit-Datenverarbeitungsanwendungen. Einführung: Mit dem Aufkommen von Big Data und Echtzeit-Datenverarbeitung ist die Erstellung von Echtzeit-Datenverarbeitungsanwendungen für viele Entwickler zum Ziel geworden. Die Kombination von React, einem beliebten Front-End-Framework, und Apache Kafka, einem leistungsstarken verteilten Messaging-System, kann uns beim Aufbau von Echtzeit-Datenverarbeitungsanwendungen helfen. In diesem Artikel wird erläutert, wie Sie mit React und Apache Kafka Echtzeit-Datenverarbeitungsanwendungen erstellen

See all articles