<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
  <channel>
    <title>Ssr on David Lang</title>
    <link>https://www.davidlang.tech/tags/ssr/</link>
    <description>Recent content in Ssr on David Lang</description>
    <generator>Hugo</generator>
    <language>en</language>
    <lastBuildDate>Wed, 20 Jan 2021 00:00:00 +0000</lastBuildDate>
    <atom:link href="https://www.davidlang.tech/tags/ssr/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Next.js: The Ultimate Guide to Server-Side Rendering</title>
      <link>https://www.davidlang.tech/posts/nextjs-the-ultimate-guide-to-server-side-rendering/</link>
      <pubDate>Wed, 20 Jan 2021 00:00:00 +0000</pubDate>
      <guid>https://www.davidlang.tech/posts/nextjs-the-ultimate-guide-to-server-side-rendering/</guid>
      <description>&lt;p&gt;Next.js extends React with file-based routing, SSR, SSG, and API routes. Understanding when each rendering mode applies is essential for performance and SEO.&lt;/p&gt;&#xA;&lt;h2 id=&#34;rendering-modes&#34;&gt;Rendering Modes&lt;/h2&gt;&#xA;&lt;p&gt;&lt;strong&gt;Static Generation (SSG)&lt;/strong&gt; pre-renders at build time-ideal for marketing pages and blogs. &lt;strong&gt;Server-Side Rendering (SSR)&lt;/strong&gt; renders on each request-best for personalized or frequently changing data. &lt;strong&gt;Client-Side Rendering (CSR)&lt;/strong&gt; hydrates in the browser for highly interactive dashboards.&lt;/p&gt;&#xA;&lt;h2 id=&#34;getserversideprops-example&#34;&gt;getServerSideProps Example&lt;/h2&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#93a1a1;background-color:#002b36;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-javascript&#34; data-lang=&#34;javascript&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#268bd2&#34;&gt;export&lt;/span&gt; &lt;span style=&#34;color:#268bd2&#34;&gt;async&lt;/span&gt; &lt;span style=&#34;color:#268bd2&#34;&gt;function&lt;/span&gt; getServerSideProps({ params }) {&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#268bd2&#34;&gt;const&lt;/span&gt; res &lt;span style=&#34;color:#719e07&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#268bd2&#34;&gt;await&lt;/span&gt; fetch(&lt;span style=&#34;color:#586e75&#34;&gt;`https://api.example.com/posts/&lt;/span&gt;&lt;span style=&#34;color:#2aa198&#34;&gt;${&lt;/span&gt;params.id&lt;span style=&#34;color:#2aa198&#34;&gt;}&lt;/span&gt;&lt;span style=&#34;color:#586e75&#34;&gt;`&lt;/span&gt;);&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#268bd2&#34;&gt;const&lt;/span&gt; post &lt;span style=&#34;color:#719e07&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#268bd2&#34;&gt;await&lt;/span&gt; res.json();&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#719e07&#34;&gt;return&lt;/span&gt; { props&lt;span style=&#34;color:#719e07&#34;&gt;:&lt;/span&gt; { post } };&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;}&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h2 id=&#34;app-router-preview&#34;&gt;App Router (Preview)&lt;/h2&gt;&#xA;&lt;p&gt;Next.js 13+ introduces the App Router with React Server Components. Pages Router patterns remain widely used-know both as you maintain legacy and greenfield apps.&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
