Github Article Archive: Link

What is “What is XXR? ?

There are many common scenarios in front-end development, which have different advantages and disadvantages and applicability according to different construction and rendering processes. For example, CSR is commonly used under the support of modern UI library, SSR (SPR) with better SEO effect, SSG generated when the main idea of transformation is built, ISR and DPR based on the vision of large architecture, and NSR and ESR, which are less heard, etc.

The proposal and improvement of many schemes bring more possibilities of technology selection, and the rapid emergence of ecological support makes the development experience and mental burden of different schemes more convenient and the developers feel nothing.

But:

  • How do the various schemes work?
  • How to choose a plan in different scenarios?
  • What are the advantages of each approach? What are the resulting weaknesses or current deficiencies?
  • What development tools, libraries, and frameworks are available to support this?

Hopefully this article will help solve the above question: “What is XXR?” .

If not complete or biased, welcome to discuss & comment.

Render mode — Concept vs. contrast

✌🏻 render mode ✌🏻, including:

  • How pages/applications are compiled after they are developed;
  • Service forms after the deployment goes online;
  • How resources are stored and distributed;
  • Startup and rendering processes for user access;
  • There are different implementations and specifications for these aspects.

This section will introduce the basic features of each rendering mode, how it works, and compare the pros and cons of each mode.

CSR for Client Side Rendering

As the name implies, “client-side rendering” is the most common solution for rendering front-end projects for various UI library builds.

What is CSR?

In this mode, the page hosting server only needs to respond to a page access request with an empty page that looks like this:

<! DOCTYPEhtml>
<html>
  <head>
    <meta charset="utf-8" />
    <! -- metas -->
    <title></title>
    <link rel="shortcut icon" href="xxx.png" />
    <link rel="stylesheet" href="xxx.css" />
  </head>
  <body>
    <div id="root"><! -- page content --></div>
    <script src="xxx/filterXss.min.js"></script>
    <script src="xxx/x.chunk.js"></script>
    <script src="xxx/main.chunk.js"></script>
  </body>
</html>
Copy the code

You can see that a view node (div#root) is set aside for filling the rendered content, and a script node pointing to the compressed JS Bundle of the project and a link. Stylesheet node pointing to the CSS file are inserted.

Browser receives the response, the document will be based on link load scripts and styles within the document resources, the main work and complete the following several aspects: execute the script, network access to online data, using the DOM API to update the page structure, binding interaction events, injection pattern, in order to complete the whole rendering process.

Advantages and disadvantages together

The CSR model has the following advantages:

  • UI library support: Common UI solutions such as React and Vue, the default Application form is SPA (for Single Page Application), which is a highly interactive and dynamic Web Application. CSR well meets the needs of this Application form and is widely supported in the mainstream technology stack.
  • Separation of front and back ends: View interaction and specific data decoupling depend on the emergence and popularity of this application form, so that the functions of the front and back ends are clear and easy to maintain and cooperate.
  • Light server load: As can be seen from the example, the page hosting service in the CSR scenario only needs to return a blank page fixed after each deployment to access requests, and the loading and rendering of other resources are handed over to the browser. The static resources (bundle, CSS and assets) of the project are all deployed on CDN, so the server has light burden and fast response. And more conducive to resource terminal and CDN cache;

Pros and cons depend on each other. Such a model also has the following defects:

  • Rendering speed is limited: Based on the above characteristics, although lighter service loads lead to faster access response times, However, the rendering speed and effect of CSR pages are easily limited. After the user browser gets the template HTML, it takes time to parse the document and JS code, logic execution and interface request, and loading static resources depends on CDN, network environment and terminal browser performance. Can greatly affect or even block page rendering, damage the user experience;
  • Bad for SEO (for Search Engine Optimization) : When a crawler requests a CSR page, it will be limited to get an empty page without content from the server, which is not conducive to the information collection and exposure of the site on the search engine (but now the crawler ability of leading search engines such as Google, Baidu and Bing can partially support the page content crawling of CSR SPA). SEO friendliness may not matter in very dynamic, interactive scenarios that are light on actual content — and even if it does, there are partial solutions, such as inserting some important information with meta/Template, and SSG, which will be covered later;
  • * Low security: One of the things we’ve heard is that in CSR scenarios, pages are more vulnerable to XSS (for Cross-Site Scripting) attacks, which hijack user sessions for malicious manipulation by exploiting entry points within the page that can interfere with logical code. CSR in terms of the relative safety of a lower point, may be more logic code required to run directly on the browser and visible, let the bad person takes more – but now more and more confused security tools, browser security deployment, code scheme background, magic and the tao is tall what is low in fact has been in the battle.

SSR for Server Side Rendering

“Things go in a spiral.”

SSR is what?

The concept of SSR, as opposed to CSR, is to do most of the rendering on the server side, which is how pages were rendered in the early days before today’s front end – the server had rendered pages ready for rendering when it responded to a site visit request. However, unlike the slash-and-burn era when pages were generated through back-end templates and other solutions, today’s SSR capabilities are increasingly powerful, and in some cases can even achieve a state of “low developer awareness” — developing SSR is not that different from CSR projects (e.g., the plant framework Jupiter’s SSR support). This depends on the development of community ecology. The framework/class library of CSR mentioned above (as well as Angular and Svelte, which are seldom practiced by the author) all have excellent SSR solutions.

Briefly describes the principle

“Rendering a page on the server means emulating a browser on the server.”

‘–‘ Yes, but not quite. ‘

UI ecosystem giants like React and Vue all have a key concept of Virtual DOM (or VDOM). The browser DOM API is too slow. They first model and process view presentation and update, and then batch adjust DOM API to complete view rendering and update. This leads to an SSR protocol:

VDOM is a self-built, abstract nested data structure that can be run in Node (or any server environment). It takes the original view code and runs it on the server, maintains it through VDOM, and finally concatenates strings as page responses and generates documents as response pages. At this point, the page content has been basically generated, the logic code, style code attached, you can achieve a complete, renderable page response.

In addition, for some content that needs to be activated on the client side, such as the Vue instance taking over the component behavior, or the React Effect triggering execution on the client side, the Bundle is generated at compile time and attached to the hyperlink script in the response page.

After magnified first

The development of SSR program was promoted again after CSR, which is to a large extent to solve some problems of CSR, which is also the prominent advantage of SSR in comparison:

  • Better presentation speed and user experience: COMPARED with CSR, SSR reduces the process of page parsing, resource loading and logical code execution after reaching the browser. After the user gets the response content, the content is basically a page that can be presented, and the first screen time is greatly shortened.
  • SEO friendly: SSR service for site access request response is filled page, which has a lot of site information and data for crawler to identify directly, needless to say, search engine optimization;

Old rule — raise before you cut. In addition to its advantages, SSR also brings some limitations:

  • High cost of introduction: SSR scheme re-transfers the view rendering work to the server, which introduces new concepts and technology stack (such as Node), and brings higher cost of server hardware and operation and maintenance.
  • Long response time: Compared with CSR, SSR requires more computation and generation when it completes the access response, so its request response Time is longer. Meanwhile, due To the response speed of the pre-data interface, TTFB (Time To First Byte), a key indicator, becomes larger.
  • Poor first screen interaction: Again, “SSR’s user startup experience is good, but not entirely good.” Although SSR can make the page render faster in the browser after the request response, it is actually not interactive when the first frame appears and the logical code (such as event binding) that needs to be loaded and activated by the client is not initialized, which also affects the user experience.
  • Traditional development ideas are limited: It is still listed as the limitations of SSR. Since the main page content is rendered on the server side, the access to the browser (or the host under Hybrid or Webview) environment and related operations are limited, and some operations have to be delayed until the client is activated. This is where the last limitation comes in.

SPR for Serverless Pre-Rendering

No service pre-render, a rendering technique under the Topic Serverless. SPR refers to the ability to transform some pages into static pages through pre-rendering and caching capabilities in SSR architecture to avoid frequent rendering when the server receives requests. Meanwhile, some frameworks also support setting the expiration time of static resources to ensure that these “static pages” can also have a certain degree of instantness.

This is a targeted optimization for SSR service with high computing cost and heavy service load. Now there are many cutting-edge frameworks to support it, and developers can introduce it very easily.

SSG for Static Site Generation

Some form of stitching strange — but in a good way.

SSG is what?

It is a stitch geek because, like CSR, it only requires page hosting without actually writing and deploying the server, and the page resources are determined before compilation and deployment are complete. But like SSR, it is a Prerender pre-render operation, meaning that the page content and structure are rendered before the user’s browser gets the page response. Of course, in terms of form and characteristics, it is closer to SSR.

  • If CSR and Prerender differ in terms of priorities for rendering, BOTH SSR and SSG Prerender are decisions about timing for rendering — or, crucially, “water flooding” — filling.
  • Or to put it another way, unlike CSR and SSR, which leave most of the rendering to request time, SSG has the page content roughly filled in by the time the site project is built and deployed.

Eventually the SSG pattern became a bit of a real “back to basics”, with increasingly dynamic, interactive pages becoming mostly populated, static pages hosted on page services/CDN.

Is it balanced well enough?

SSG combines the advantages of traditional CSR and SSR, and makes good complement to the shortcomings of the two. The advantages of low service burden, better loading performance and experience, and SEO friendliness are not to be analyzed separately here, but there are also some benefits that come from the model itself:

  • Page content is statically generated, page deployment only needs a simple page hosting server, or even only needs to be placed on the CDN, greatly reducing the dynamic, and the server to page loading, rendering work intervention, also let malicious attacks a lot less opportunities;

The shortcomings of SSG are also worth discussing:

  • As applications expand and become more complex, the number of pre-rendered pages grows rapidly. SSG projects have high build and deployment costs. The more complex the application, the more static pages need to be built. For large, feature-rich sites, it is possible to render thousands of pages per build, which inevitably leads to high deployment and update costs.
  • Highly static brings impromptness. The time node to ensure the validity of SSG generated parts in the page accessed by users is the last construction, which makes the application in this mode lose part of timeliness. This part of defect needs to be made up through timed construction or part of non-SSG, which is also the main problem of SSG.

BTW

Now that we’ve talked about it, let’s talk about it.

There are also XXRS, which are not large groups or holistic solutions like CSR/SSR, but performance strategies and optimization methods that rely on technical capabilities in a larger architecture. These are listed and briefly introduced here.

NSR for Native Side Rendering *

Native is a client, everything can be distributed, can be understood as a kind of distributed SSR, but here the rendering work is handed over to the client rather than the remote server. Page data is prefetched in the upper level of the page that the user is about to visit, and THE HTML structure is cached by the client to achieve the effect of fast response when the user really visits the page.

NSR is found in Hybrid scenarios of mobile + Webview, and is an optimization method that requires collaboration between the page and client development.

ESR for Edge Side Rendering *

Edge refers to the Edge. Compared with the previous XSR, ESR refers to handing over the rendering work to the Edge server node, commonly known as the Edge node of CDN. This scheme mainly focuses on the distance advantage between edge nodes and users compared with the core server, and makes use of the concept of CDN hierarchical cache. Rendering and content filling can also be hierarchical and cached.

ESR under static content and dynamic content is the shunt, CDN edge node can be static page content first response to the user, and then a dynamic content request, get the core server response is then returned to the user, is in a large network architecture is a kind of optimization to the extreme, but it is also dependent on larger technical infrastructure system.

ISR for Incremental Site Rendering

Literal translation, incremental site rendering. It is also easy to understand that the page content is treated with a knife cut, there is a finer differentiation of render granularity, can be gradual, layered rendering. Common choices are: For important pages such as the first screen and the direct landing page with large traffic volume, pre-render and add cache to ensure the best access performance; For secondary pages, ensure that there are pockets of content that can be fallback in real time, leave rendering of real time data to the CSR level, and trigger asynchronous cache updates.

For “asynchronous cache update”, it is necessary to mention a common content cache strategy: Stale While Revalidate. CDN always responds to data requests with cached content first, and if the content has expired, asynchronous update will be triggered after the response — this is also the caching method for minor elements or pages.

Based on this, what CDN does is to directly respond to each request of the user, and update the cached pre-rendered resources when the user triggers fallback and the current pre-rendered page expires and is accessed by the user again. The client has the following bad experience in perception:

  1. Fallback is triggered when accessing secondary content that has not been pre-rendered, which requires CSR and slow loading.
  2. Access to pages that have been pre-rendered but have expired and not been updated will first get expired cache response, and access to new resources only after triggering CDN asynchronous cache update, resulting in inconsistent experience.

DPR for Distributed Persistent Rendering

DPR is a new proposal from cloud computing company Netlify just a few months ago (2020/04). It is an upgrade based on the basic MODEL of ISR and an optimization for the lack of instantaneity of ISR.

After looking at the definition and proposal I am not sure what DPR should be called. It is probably “distributed persistent/persistent rendering” because it utilizes the CDN distribution node for rendering requests — distribution (and the render timing is also distributed at build/request time); Again, a gradual process on demand — continuity; At the same time, CDN is built on the basis of caching ability – persistence.

This sounds a bit like NSR in terms of distribution, and a lot like ESR. In fact, distribution here is completely different from NSR, but it does have a lot in common with ESR, even an improved version of it. Here is a brief introduction using the diagram from the proposal:

The dotted box on the left is the build process, with DPR functions in the middle being some Serverless or on-demand build functions on the core page server, then CDN cache nodes, and finally to the user browser.

In the Build phase, generate site is completed. This step does not complete all builds, but only generates key resources to be deployed on the page hosting service or CDN. For other content, there is an on-demand process — the CDN will request a build in real time on the first access request, and return the latest build results to the user, and add this part of content to the original cache resources; Cached resources will also be invalidated during the next build update.

How to choose

— Now I choose 😵💫

These options are not completely side-by-side and it is difficult to fully “branch decisions”. Here are a few concerns under consideration:

Feature concerns:

  • Do you care about SEO?
    • Yes: pre-render is required, pure CSR is not desirable
    • No: Unlimited
  • Is it rich in interactivity, requires user capabilities, differentiated rendering
    • Yes: CSR is convenient and SSR is fast to load
    • No: Pre-render series guarantees loading experience
  • Page structure & complexity of routing, frequency of data updates, dependence on real-time data interface
    • Yes: Exclude SSG first. If the content cannot be disassembled, ISR and DPR cannot be accessed
    • No: Unlimited

Dependency concerns:

  • Whether to accept server O&M costs
    • Yes: Unlimited, SSR flushable
    • If no, the SSR option is lost
  • Is there any browser dependency in the older implementation such as the use of DOM, BOM, or JSBridge in a Hybrid scenario within the UI framework
    • Yes: SSR and SSG are restricted
    • No: Unlimited

The above considerations are not limited, so choose the model with relatively complete technical infrastructure support that can best meet the characteristics of the project