preface
Today our topic is: Vue SSR, this term I believe we are not unfamiliar, but now we do some projects will not be used, that SSR is how to achieve it? And when should it be used? Today we will start from the Vue SSR realization, a complete walk through the process, come together ~
PS: VUE-SSR will be divided into three parts: understanding SSR and practice in Vue (part 1), isomic development of SSR application in Vue (Part 2), nuxt.js practice (part 2)
What is the SSR
SSR is Server Side Render, ennnn. What is server-side rendering? Let’s start with the step-by-step evolution of Web development
Traditional Web Development
As we all know, the web development work in the start at the beginning of the basic it is actually the back-end developers to complete, then it wasn’t even front-end development engineer in this position, the time is not separation (such as JSP this) before and after the end, that is web content is in the rendering of a service is completed, then a one-time transfer to the browser.
Let’s draw a picture to give you an idea of the process:
From the diagram above we can see the traditional web development pattern. Let’s use Node to build a simple server to simulate the previous approach:
The node server code is as follows:
const express = require("express")
const app = express()
app.get("/".(req, res) = > {
res.send(`<h3>hello,guangying</h3>`);
});
app.listen(3000.() = > {
console.log("server running...");
});
Copy the code
We run it and right click to display the web source and we can see the result:
So with the above description, we see that this way the browser gets the full DOM structure
SPA (Single Page App)
The result of the traditional development mode is that the user experience is not very good, but the excellent user experience of single-page application gradually develops into the mainstream. The page content is rendered by JS, which is also called client rendering
Let’s also draw a diagram to show the general process:
From above, we found that, compared to traditional web development, SPA way if you want to complete appear in front of the user, so network need to experience two requests, at least for the first time the server returned to the client just page frame, not the actual content, the real content is after the js code to be executed when the client will be generated
Here we take Vue as an example, using Node to simulate this approach:
const express = require('express')
const app = express()
app.get('/'.(req, res) = > {
const html = `
hello, guangying
`
res.send(html)
})
app.listen(3030.() = > {
console.log('server running2... ')})Copy the code
Let’s also check by looking at the source code of the web page, as shown below:
Through analysis, we can basically conclude the advantages and disadvantages of SPA mode:
Advantages:
- Rendering computations are placed on the client side, which takes the pressure off the server side
- Because it is a single page application, some traffic will be saved
Disadvantages:
- The loading speed of the first screen is slow, especially when the network environment is poor
- Bad for search engine SEO
SSR (Server Side Render)
Due to the flaws of the two ways before, so he had the SSR, it was quite lies between the former two, SSR solution: the service side apply colours to a drawing gives a complete return to the first screen of DOM structure, the content of the front end can get including first screen and the complete SPA structure, application of activated still operate in the manner of SPA, this way of rendering is the SSR
PS:
- To put it simply, it is the combination and improvement between the former two
- One concept to mention here — the first screen! The first screen! The first screen! Important things to say three times, not just the front page, here feel very confused
Let’s also draw a picture to show it:
Through the process of learning SSR, we found that he solved the problems of the first two, because the first screen is rendered on the server, SEO can get the results correctly; At the same time, when the first screen is returned to the client after rendering, SSR can also carry routing information, state management information and so on to the front end. Simply speaking, the back end is all the structure of the first screen and the structure of SPA mode, so that the first screen rendering is improved
Next, we take Vue as an example to carry out Vue SSR practice:
1. Install dependencies: Vue server render module: VUe-server-renderer
Make sure that Vue and vue-server-renderer versions are the same when installing dependencies
npm install vue-server-renderer@2.610. -S
Copy the code
2. Run the script:
const express = require('express')
const app = express()
// import Vue
const Vue = require('vue')
// import createRenderer and get renderer
const {createRenderer} = require('vue-server-renderer')
const renderer = createRenderer()
app.get(The '*'.async (req, res) => {
// create a Vue instance to render
const vm = new Vue({
template: ` hello,{{name}}
`.data() {
return {
name: 'guangying'}}})try {
// renderToString renders the vue instance as an HTML string that returns a Promise
const html = await renderer.renderToString(vm)
// Return HTML to the client
res.send(html)
} catch (error) {
console.log(error)
}
})
app.listen(3333.() = > {
console.log('sever running3')})Copy the code
After writing, we run and also look at the source code of the web page, as shown in the figure below:
We can see that at this point we have the complete DOM structure, but notice the attributes in the red box. This is for Vue. With this information, Vue knows that this is what the server rendered and will have the credentials for future activation
This example is the most basic SSR example. Let’s see what happens when vue-Router is added:
const express = require('express')
const app = express()
// import Vue
const Vue = require('vue')
Vue / / in the router
const Router = require('vue-router')
Vue.use(Router)
const {createRenderer} = require('vue-server-renderer')
const renderer = createRenderer()
// Change path to wildcard
app.get(The '*'.async (req, res) => {
// Create one routing instance at a time
const router = new Router({
routes: [{path: '/'.component: {template: ' This is the home page
'}},
{path: '/detail'.component: {template: ' Here are the details
'}}}])const vm = new Vue({
// Add the router-view to display the contents
template: ` < div > < h1 > hello, {{name}} < / h1 > < the router - link to = "/" > home page < / router - the link > < the router - link to = "/ detail" > detail < / router - the link >
`,
router, / / a mount
data() {
return {
name: 'guangying'}}})try {
// Jump to the corresponding route
router.push(req.url)
const html = await renderer.renderToString(vm)
res.send(html)
} catch (error) {
console.log(error)
}
})
app.listen(3333.() = > {
console.log('sever running3')})Copy the code
In fact, at this point, we have about the basic practice of Vue SSR, but let’s think about what problems we will have with the way we write now?
For example, we write this way to mix the server side and the front end together, so that our development burden will increase, and the code is not beautiful and easy to maintain, can we follow the familiar way of Vue development?
Another example is if we want to add user events how do we make them work? Since you’re returning HTML strings, writing them in the familiar Vue way doesn’t work. In other words, how do you activate subsequent clients?
In this article, we mainly introduce the basic definition and basic practice of SSR. We should first understand its realization principle and realization process. In the next chapter, we continue to learn how to use isomorphism to complete the server rendering and client activation
At the end of the article
Welcome to pay attention to the “front-end light and shadow” public account, the public account is in the form of the system thematic module to show, so it looks more convenient, system, let us continue to learn all kinds of front-end knowledge, come on!