Logo

dev-resources.site

for different kinds of informations.

Client-side Rendering & Server-side Rendering

Published at
11/20/2024
Categories
csr
ssr
webdev
javascript
Author
arjad_gohar_f6d9b8938c997
Categories
4 categories in total
csr
open
ssr
open
webdev
open
javascript
open
Author
25 person written this
arjad_gohar_f6d9b8938c997
open
Client-side Rendering & Server-side Rendering

Client-side rendering, also referred to as CSR, the browser renders the page itself with the use of JS. Instead of sending a ready-made page from the server, the server provides the JavaScript that will run in the browser and construct the content as the user interacts with the site. We have a lot of examples of client-side rendering websites, i.e facebook, and other social media, as they need continuous page load.

Process:

  • Server sends an initial HTML file.
  • Client-side download JS code from server.
  • The JS code outputs the final UI.

Image description

Pros:
- More dynamic and interactive web applications.
- It provides a smoother experience for users and every load.
- It reduces the extra need for server-side-requests.

Cons:
- It has slower initial load times.

Server-side rendering, also abbreviated as SSR, is when the server composes and sends to client-side a fully-formed HTML page which includes all dynamic content. The browser, then, simply displays the page without any need to do extra work. As a result, users view content at a faster speed since all processing happens on the server side. For example, as I have read somewhere that wordpress & github are based on server-side rendering (correct me, if I am wrong)

Process:

  • Server receives a request for the web page, retrieves the data required, populates into an HTML, and applies the necessary styles.
  • Now, the fully rendered page is sent by the server to the browser to show.
  • In the case of initial page loading, no type of JS is required.
  • Subsequent user interactions and updates are managed by the client-side JS rendering.

Image description

Pros:
- It loads faster the first time.
- Better user experience even with a slower network.

Cons:
- More server load requires.
- It will be slow when it is requested multiple times.

In a nutshell:
Image description

At last, I will add my own opinion to it, for applications that consider interactivity and user engagement as the top aspects, like social media or web applications with lots of client-side logic, CSR stands the best. However, where content is heavy, such as websites with more of an interest in SEO and fast initial load speeds, SSR will be a better option. It depends on the nature of the application and target audience to be determined.

Thus, by careful analysis of the strength and weakness, the developer can take a decision to have the right rendering strategy balancing performance, usability, and searchability.

Happy Coding. Thanks.

Featured ones: