{"id":48940,"date":"2024-08-28T07:00:00","date_gmt":"2024-08-28T14:00:00","guid":{"rendered":"https:\/\/dhblog.dream.press\/blog\/?p=48940"},"modified":"2025-05-21T20:05:07","modified_gmt":"2025-05-22T03:05:07","slug":"react-server-components","status":"publish","type":"post","link":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/","title":{"rendered":"React Server Components: The Future of React Development"},"content":{"rendered":"\n<p>React&#8217;s been a powerhouse for building web apps over the last <a href=\"https:\/\/vercel.com\/blog\/10-years-of-react\" target=\"_blank\" rel=\"noreferrer noopener\">ten years<\/a>.<\/p>\n\n\n\n<p>We&#8217;ve all seen it evolve from those clunky class components to the elegance of hooks.<\/p>\n\n\n\n<p>But React Server Components (RSCs)?<\/p>\n\n\n\n<p>We don\u2019t think anyone expected such a dramatic shift in how React worked.<\/p>\n\n\n\n<p>So, what exactly are React Server Components? How do they work? And what do they do differently that React couldn&#8217;t already do?<\/p>\n\n\n\n<p>To answer all these questions, we\u2019ll quickly go over the fundamentals. If you\u2019re in need of a refresher, have a quick look at this <a href=\"https:\/\/www.dreamhost.com\/blog\/learn-react\/\" target=\"_blank\" rel=\"noreferrer noopener\">guide on how to learn React as a beginner<\/a>.<\/p>\n\n\n\n<p>In this post, we\u2019ll walk you through why we needed React Server Components, how they work, and some of the major benefits of RSCs.<\/p>\n\n\n\n<p>Let\u2019s get started!<\/p>\n\n\n\n<h2 id=\"h-what-are-react-server-components\" class=\"wp-block-heading\">What Are React Server Components?<\/h2>\n\n\n\n<figure class=\"wp-block-image size-full\"><img decoding=\"async\" width=\"2400\" height=\"1800\" data-src=\"https:\/\/www.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree.webp\" alt=\"Tree diagram of React Server Components shows the hierarchy and where different component types are rendered in the app.\" class=\"wp-image-48948 lazyload\" data-srcset=\"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree.webp 2400w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-300x225.webp 300w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-1024x768.webp 1024w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-768x576.webp 768w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-1536x1152.webp 1536w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-2048x1536.webp 2048w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-600x450.webp 600w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-1200x900.webp 1200w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-730x548.webp 730w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-1460x1095.webp 1460w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-784x588.webp 784w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-1568x1176.webp 1568w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-877x658.webp 877w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/01_react_server_components_tree-1754x1316.webp 1754w\" data-sizes=\"(max-width: 2400px) 100vw, 2400px\" src=\"data:image\/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==\" style=\"--smush-placeholder-width: 2400px; --smush-placeholder-aspect-ratio: 2400\/1800;\" \/><\/figure>\n\n\n\n<p>Think of React Server Components as a new way of building React applications. Instead of running in the browser like typical React components, RSCs execute directly on your server.<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>\u201cI think RSCs are designed to be the &#8220;componentization&#8221; of the back end, i.e., the back end equivalent of what <a href=\"https:\/\/single-spa.js.org\/docs\/ecosystem-react\/\" target=\"_blank\" rel=\"noreferrer noopener\">SPA React<\/a> did for the front end. In theory, they could largely eliminate the need for things like REST and GraphQL, leading to a much tighter integration between the server and client since a component could traverse the entire stack.\u201d \u2014 <a href=\"https:\/\/www.reddit.com\/r\/reactjs\/comments\/1c9yuwj\/comment\/l0ov9jw\/?utm_source=share&amp;utm_medium=web3x&amp;utm_name=web3xcss&amp;utm_term=1&amp;utm_content=share_button\" target=\"_blank\" rel=\"noreferrer noopener\">ExternalBison54 on Reddit<\/a><\/p>\n<\/blockquote>\n\n\n\n<p>Since RSCs execute directly on the server, they can efficiently access backend resources like databases and <a href=\"https:\/\/help.dreamhost.com\/hc\/en-us\/articles\/217560167-Application-programming-interface-overview\" target=\"_blank\" rel=\"noreferrer noopener\">APIs<\/a> without an additional data fetching layer.<\/p>\n\n\n\n\n\n<div class=\"glossary-term\">\n\t<a\n\t\tclass=\"glossary-term__above-title\"\n\t\thref=\"\"\n\t\ttarget=\"_blank\"\n\t\trel=\"noopener noreferrer\"\n\t>\n\t\t<svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" viewBox=\"0 0 640 512\"><path d=\"M320 32c-8.1 0-16.1 1.4-23.7 4.1L15.8 137.4C6.3 140.9 0 149.9 0 160s6.3 19.1 15.8 22.6l57.9 20.9C57.3 229.3 48 259.8 48 291.9v28.1c0 28.4-10.8 57.7-22.3 80.8c-6.5 13-13.9 25.8-22.5 37.6C0 442.7-.9 448.3 .9 453.4s6 8.9 11.2 10.2l64 16c4.2 1.1 8.7 .3 12.4-2s6.3-6.1 7.1-10.4c8.6-42.8 4.3-81.2-2.1-108.7C90.3 344.3 86 329.8 80 316.5V291.9c0-30.2 10.2-58.7 27.9-81.5c12.9-15.5 29.6-28 49.2-35.7l157-61.7c8.2-3.2 17.5 .8 20.7 9s-.8 17.5-9 20.7l-157 61.7c-12.4 4.9-23.3 12.4-32.2 21.6l159.6 57.6c7.6 2.7 15.6 4.1 23.7 4.1s16.1-1.4 23.7-4.1L624.2 182.6c9.5-3.4 15.8-12.5 15.8-22.6s-6.3-19.1-15.8-22.6L343.7 36.1C336.1 33.4 328.1 32 320 32zM128 408c0 35.3 86 72 192 72s192-36.7 192-72L496.7 262.6 354.5 314c-11.1 4-22.8 6-34.5 6s-23.5-2-34.5-6L143.3 262.6 128 408z\"\/><\/svg>\n\t\t<span><\/span>\n\t\t<svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" viewBox=\"0 0 384 512\"><path d=\"M342.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L274.7 256 105.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z\"\/><\/svg>\n\t<\/a>\n    <h3>API<\/h3>\n    <p>An Application Programming Interface (API) is a set of functions enabling applications to access data and interact with external components, serving as a courier between client and server.<\/p>\n            <a\n            href=\"https:\/\/www.dreamhost.com\/glossary\/web-design\/api\/\"\n                        class=\"btn btn--white-outline btn--sm btn--round\"\n                                    target=\"_blank\"\n            rel=\"noopener noreferrer\"\n            >\n                            Read More                    <\/a>\n\n<\/div>\n\n\n\n<p><strong>But why did we need RSCs anyway?<\/strong><\/p>\n\n\n\n<p>To answer this question, let&#8217;s rewind a bit.<\/p>\n\n\n\n<h2 id=\"h2_traditional-react-client-side-rendering-csr\" class=\"wp-block-heading\">Traditional React: Client-Side Rendering (CSR)<\/h2>\n\n\n\n<p>React has always been a client-side UI library.<\/p>\n\n\n\n<p>The core idea behind React is to divide your entire design into smaller, independent units we call components. These components can manage their own private data (<strong>state<\/strong>) and pass data to each other (<strong>props<\/strong>).<\/p>\n\n\n\n<p>Think of these components as <a href=\"https:\/\/www.dreamhost.com\/blog\/learn-javascript\/\" target=\"_blank\" rel=\"noreferrer noopener\">JavaScript functions<\/a> that download and run right in the user&#8217;s browser. When someone visits your app, their browser downloads all the component code, and React steps in to render everything:<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img decoding=\"async\" width=\"2400\" height=\"1800\" data-src=\"https:\/\/www.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_.webp\" alt=\"Flowchart: Client-side rendering workflow, from user request to page load, including server response and browser processing.\" class=\"wp-image-48950 lazyload\" data-srcset=\"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_.webp 2400w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-300x225.webp 300w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-1024x768.webp 1024w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-768x576.webp 768w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-1536x1152.webp 1536w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-2048x1536.webp 2048w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-600x450.webp 600w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-1200x900.webp 1200w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-730x548.webp 730w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-1460x1095.webp 1460w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-784x588.webp 784w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-1568x1176.webp 1568w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-877x658.webp 877w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/02_how_client_side_rendering_works_-1754x1316.webp 1754w\" data-sizes=\"(max-width: 2400px) 100vw, 2400px\" src=\"data:image\/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==\" style=\"--smush-placeholder-width: 2400px; --smush-placeholder-aspect-ratio: 2400\/1800;\" \/><\/figure>\n\n\n\n<ul class=\"wp-block-list\">\n<li>The browser downloads the HTML, JavaScript, <a href=\"https:\/\/www.dreamhost.com\/blog\/css-transform\/\" target=\"_blank\" rel=\"noreferrer noopener\">CSS<\/a>, and other assets.<\/li>\n\n\n\n<li>React analyzes the <a href=\"https:\/\/www.dreamhost.com\/blog\/learn-html\/\" target=\"_blank\" rel=\"noreferrer noopener\">HTML<\/a>, sets up event listeners for user interactions, and retrieves any required data.<\/li>\n\n\n\n<li>The website transforms into a fully functional React application right before your eyes and everything is done by your browser and computer.<\/li>\n<\/ul>\n\n\n\n<p><strong>While this process works, it does have some downsides:<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>Slow load times:<\/strong> Loading times can be slow, particularly for complex applications with lots of components since now the user has to wait for everything to be downloaded first.<\/li>\n\n\n\n<li><strong>Bad for <\/strong><a href=\"https:\/\/www.dreamhost.com\/blog\/improve-seo\/\" target=\"_blank\" rel=\"noreferrer noopener\"><strong>search engine optimization (SEO)<\/strong><\/a>: The initial HTML is often barebones \u2014 just enough to download the JavaScript which then renders the rest of the code. This makes it hard for search engines to understand what the page is about.<\/li>\n\n\n\n<li><strong>Gets slower as apps grow larger: <\/strong>The client-side processing of JavaScript can strain resources, leading to a rougher user experience, especially as you add more functionality.<\/li>\n<\/ul>\n\n\n\n<div class=\"article-newsletter article-newsletter--gradient\">\n\n\n<h2>Get Content Delivered Straight to Your Inbox<\/h2><p>Subscribe now to receive all the latest updates, delivered directly to your inbox.<\/p><form class=\"nwsl-form\" id=\"newsletter_block_\" novalidate><div class=\"messages\"><\/div><div class=\"form-group\"><label for=\"input_newsletter_block_\"><input type=\"email\"name=\"email\"id=\"input_newsletter_block_\"placeholder=\"Enter your email address\"novalidatedisabled=\"disabled\"\/><\/label><button type=\"submit\"class=\"btn btn--brand\"disabled=\"disabled\"><span>Sign Me Up!<\/span><svg width=\"21\" height=\"14\" viewBox=\"0 0 21 14\" fill=\"none\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\">\n<path d=\"M13.8523 0.42524L12.9323 1.34521C12.7095 1.56801 12.7132 1.9304 12.9404 2.14865L16.7241 5.7823H0.5625C0.251859 5.7823 0 6.03416 0 6.3448V7.6573C0 7.96794 0.251859 8.2198 0.5625 8.2198H16.7241L12.9405 11.8535C12.7132 12.0717 12.7095 12.4341 12.9323 12.6569L13.8523 13.5769C14.072 13.7965 14.4281 13.7965 14.6478 13.5769L20.8259 7.39879C21.0456 7.17913 21.0456 6.82298 20.8259 6.60327L14.6477 0.42524C14.4281 0.205584 14.0719 0.205584 13.8523 0.42524Z\" fill=\"white\"\/>\n<\/svg>\n<\/button><\/div><\/form><\/div>\n\n\n<h2 id=\"h2_the-next-iteration-server-side-rendering-ssr\" class=\"wp-block-heading\">The Next Iteration: Server-Side Rendering (SSR)<\/h2>\n\n\n\n<p>To address the issues caused by client-side rendering, the React community adopted Server-Side Rendering (SSR).<\/p>\n\n\n\n<p>With SSR, the server handles rendering the code to HTML before sending it over.<\/p>\n\n\n\n<p>This complete, rendered HTML is then transferred to your browser\/mobile, ready to be viewed \u2014 the app doesn\u2019t need to be <em>compiled<\/em> during runtime like it would without SSR.<\/p>\n\n\n\n<p><strong>Here\u2019s how SSR works:<\/strong><\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img decoding=\"async\" width=\"2400\" height=\"1800\" data-src=\"https:\/\/www.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_.webp\" alt=\"Diagram showing how server-side rendering works, with browser requesting HTML from server and receiving fully rendered page.\" class=\"wp-image-48953 lazyload\" data-srcset=\"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_.webp 2400w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-300x225.webp 300w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-1024x768.webp 1024w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-768x576.webp 768w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-1536x1152.webp 1536w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-2048x1536.webp 2048w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-600x450.webp 600w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-1200x900.webp 1200w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-730x548.webp 730w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-1460x1095.webp 1460w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-784x588.webp 784w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-1568x1176.webp 1568w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-877x658.webp 877w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/03_how_server_side_rendering_works_-1754x1316.webp 1754w\" data-sizes=\"(max-width: 2400px) 100vw, 2400px\" src=\"data:image\/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==\" style=\"--smush-placeholder-width: 2400px; --smush-placeholder-aspect-ratio: 2400\/1800;\" \/><\/figure>\n\n\n\n<ul class=\"wp-block-list\">\n<li>The server renders the initial HTML for each request.<\/li>\n\n\n\n<li>The client receives a fully formed HTML structure, allowing for faster initial page loads.<\/li>\n\n\n\n<li>The client then downloads React and your application code, a process called \u201chydration,\u201d which makes the page interactive.<\/li>\n<\/ul>\n\n\n\n<p>The HTML structure rendered on the server has no functionality \u2014 yet.&nbsp;<\/p>\n\n\n\n<p>React adds event listeners, sets up internal state management, and adds other functionality to the HTML after it\u2019s been downloaded to your device. This process of adding \u201clife\u201d to the page is known as hydration.<\/p>\n\n\n\n<p>Why does SSR work so well?<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>Faster initial load times<\/strong>: Users see the content almost instantly because the browser receives fully formed HTML, eliminating the time required for the JavaScript to load and execute.<\/li>\n\n\n\n<li><strong>Improved SEO<\/strong>: Search engines easily crawl and index server-rendered HTML. This direct access translates to better search engine optimization for your application.<\/li>\n\n\n\n<li><strong>Enhanced performance on slower devices:<\/strong> SSR lightens the load on a user&#8217;s device. The server shoulders the work, making your application more accessible and performant, even on slower connections.<\/li>\n<\/ol>\n\n\n\n<p>SSR, however, caused a number of additional problems, calling for an even better solution:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>Slow Time to Interactive (TTI): <\/strong>Server-side rendering and hydration delay the user&#8217;s ability to see and interact with the app until the entire process is complete.<\/li>\n\n\n\n<li><strong>Server load: <\/strong>The server needs to do more work, further slowing down response times for <a href=\"https:\/\/www.dreamhost.com\/blog\/how-to-hire-web-developer\/\" target=\"_blank\" rel=\"noreferrer noopener\">complex applications<\/a>, especially when there are many users simultaneously.<\/li>\n\n\n\n<li><strong>Setup complexity: <\/strong>Setting up and maintaining can be more complex, especially for large applications.<\/li>\n<\/ul>\n\n\n\n<h2 id=\"h2_finally-the-react-server-components\" class=\"wp-block-heading\">Finally, the React Server Components<\/h2>\n\n\n\n<p>In December 2020, the React team introduced the \u201c<a href=\"https:\/\/react.dev\/blog\/2020\/12\/21\/data-fetching-with-react-server-components\" target=\"_blank\" rel=\"noreferrer noopener\">Zero-Bundle-Size React Server Components<\/a>\u201d or RSCs.<\/p>\n\n\n\n<style>.embed-container { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; max-width: 100%; } .embed-container iframe, .embed-container object, .embed-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }<\/style><div class='embed-container'><iframe data-src='https:\/\/www.youtube.com\/embed\/TQQPAU21ZUw' frameborder='0' allowfullscreen src='data:image\/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==' class='lazyload' data-load-mode='1'><\/iframe><\/div>\n\n\n\n<p>This changed not only how we thought about building React apps but also how React apps work behind the scenes. RSCs solved many problems we had with CSR and SSR.<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p>\u201cWith RSCs, React becomes a fully server-side framework and a fully client-side framework, which we&#8217;ve never had before. And that allows a much closer integration between the server and client code than was ever possible before.\u201d \u2014 <a href=\"https:\/\/www.reddit.com\/r\/reactjs\/comments\/1c9yuwj\/comment\/l0ov9jw\/?utm_source=share&amp;utm_medium=web3x&amp;utm_name=web3xcss&amp;utm_term=1&amp;utm_content=share_button\" target=\"_blank\" rel=\"noreferrer noopener\">ExternalBison54 on Reddit<\/a><\/p>\n<\/blockquote>\n\n\n\n<p><strong>Let\u2019s now look at the benefits that RSCs bring to the table:<\/strong><\/p>\n\n\n\n<h3 class=\"wp-block-heading\">1. Zero Bundle Size<\/h3>\n\n\n\n<p>RSCs are rendered entirely on the server, eliminating the need to send JavaScript code to the client. This results in:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Dramatically smaller JavaScript bundle sizes.<\/li>\n\n\n\n<li>Faster page loads, particularly on slower networks.<\/li>\n\n\n\n<li>Improved performance on less powerful devices.<\/li>\n<\/ul>\n\n\n\n<p>Unlike SSR, where the entire React component tree is sent to the client for hydration, RSCs keep server-only code on the server. This leads to those significantly smaller client-side bundles we talked about, making your applications lighter and more responsive.<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">2. Direct Backend Access<\/h3>\n\n\n\n<p>RSCs can interact directly with databases and file systems without requiring an API layer.<\/p>\n\n\n\n<p>As you can see in the code below, the <strong>courses<\/strong> variable is fetched directly from the database, and the UI prints a list of the <strong>course.id<\/strong> and <strong>course.name<\/strong> from the <strong>courses.map<\/strong>:<\/p>\n\n\n\n<p><code>async function CourseList() {<br>&nbsp; const db = await connectToDatabase();<br>&nbsp; const courses = await db.query('SELECT * FROM courses');<br><br>&nbsp; return (<br>&nbsp; &nbsp; &lt;ul&gt;<br>&nbsp; &nbsp; &nbsp; {courses.map(course =&gt; (<br>&nbsp; &nbsp; &nbsp; &nbsp; &lt;li key={course.id}&gt;{course.name}&lt;\/li&gt;<br>&nbsp; &nbsp; &nbsp; ))}<br>&nbsp; &nbsp; &lt;\/ul&gt;<br>&nbsp; );<br>}<\/code><\/p>\n\n\n\n<p>This is simpler in contrast to traditional SSR where you\u2019d need to set up separate API routes for fetching individual pieces of data.<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">3. Automatic Code Splitting<\/h3>\n\n\n\n<p>With RSCs, you also get more granular code splitting and better code organization.<\/p>\n\n\n\n<p>React keeps server-only code on the server and ensures that it never gets sent over to the client. The client components are automatically identified and sent to the client for hydration.<\/p>\n\n\n\n<p>And the overall bundle becomes extremely optimized since the client now receives exactly what\u2019s needed for a fully functional app.<\/p>\n\n\n\n<p>On the other hand, SSR needs careful manual code splitting to optimize performance for each additional page.<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"h-4-reduced-waterfall-effect-and-streaming-rendering\">4. Reduced Waterfall Effect and Streaming Rendering<\/h3>\n\n\n\n<p>React Server Components combine streaming rendering and parallel data fetching. This powerful combination significantly reduces the \u201cwaterfall effect\u201d often seen in traditional server-side rendering.<\/p>\n\n\n\n<h4 class=\"wp-block-heading\">Waterfall Effect<\/h4>\n\n\n\n<p>The &#8220;waterfall effect&#8221; slows down web development. Basically, it forces the operations to follow one another as if a waterfall were flowing over a series of rocks.<\/p>\n\n\n\n<p>Each step must wait for the previous one to finish. This &#8220;wait&#8221; is especially noticeable in data fetching. One API call must be completed before the next one begins, causing page load times to slow.<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><img decoding=\"async\" width=\"1024\" height=\"547\" data-src=\"https:\/\/www.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-1024x547.webp\" alt=\"Table from Chrome Network Tab displays the waterfall effect of network requests, showing various API calls and their timing.\" class=\"wp-image-48955 lazyload\" data-srcset=\"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-1024x547.webp 1024w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-300x160.webp 300w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-768x410.webp 768w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-1536x820.webp 1536w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-2048x1093.webp 2048w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-600x320.webp 600w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-1200x641.webp 1200w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-730x390.webp 730w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-1460x779.webp 1460w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-784x418.webp 784w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-1568x837.webp 1568w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-877x468.webp 877w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/04_waterfall_effect-1754x936.webp 1754w\" data-sizes=\"(max-width: 1024px) 100vw, 1024px\" src=\"data:image\/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==\" style=\"--smush-placeholder-width: 1024px; --smush-placeholder-aspect-ratio: 1024\/547;\" \/><\/figure>\n\n\n\n<h4 class=\"wp-block-heading\">Streaming Rendering<\/h4>\n\n\n\n<p>Streaming rendering offers a solution. Instead of waiting for the entire page to render on the server, the server can send pieces of the UI to the client as soon as they&#8217;re ready.<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img decoding=\"async\" width=\"2400\" height=\"1691\" data-src=\"https:\/\/www.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering.webp\" alt=\"Diagram shows streaming server rendering: network requests and JavaScript execution timeline, including FCP and TTI markers.\" class=\"wp-image-48957 lazyload\" data-srcset=\"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering.webp 2400w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-300x211.webp 300w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-1024x721.webp 1024w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-768x541.webp 768w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-1536x1082.webp 1536w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-2048x1443.webp 2048w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-600x423.webp 600w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-1200x846.webp 1200w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-730x514.webp 730w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-1460x1029.webp 1460w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-784x552.webp 784w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-1568x1105.webp 1568w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-877x618.webp 877w, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/05_streaming_server_rendering-1754x1236.webp 1754w\" data-sizes=\"(max-width: 2400px) 100vw, 2400px\" src=\"data:image\/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==\" style=\"--smush-placeholder-width: 2400px; --smush-placeholder-aspect-ratio: 2400\/1691;\" \/><\/figure>\n\n\n\n<p>React Server Components make rendering and fetching data much smoother. It creates multiple server components that work in parallel avoiding this waterfall effect.<\/p>\n\n\n\n<p>The server starts sending HTML to the client the moment any piece of the UI is ready.<\/p>\n\n\n\n<p><strong>So, compared to server-side rendering, RSCs:<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Allow each component to fetch its data independently and in parallel.<\/li>\n\n\n\n<li>The server can stream a component as soon as its data is ready, without waiting for other components to catch up.<\/li>\n\n\n\n<li>Users see the content loading one after the other, enhancing their perception of performance.<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">5. Smooth Interaction With Client Components<\/h3>\n\n\n\n<p>Now, using RSCs doesn\u2019t necessarily imply that you have to skip using client-side components.&nbsp;<\/p>\n\n\n\n<p>Both components can co-exist and help you create a great overall app experience.<\/p>\n\n\n\n<p>Think of an e-commerce application. With SSR, the entire app needs to be rendered server side.<\/p>\n\n\n\n<p>In RSCs, however, you can select which components to render on the server and which ones to render on the client side.<\/p>\n\n\n\n<p>For instance, you could use server components to fetch product data and render the initial product listing page.<\/p>\n\n\n\n<p>Then, client components can handle user interactions like adding items to a shopping cart or managing product reviews.<\/p>\n\n\n\n<h2 id=\"h2_should-you-add-rsc-implementation-on-your-roadmap\" class=\"wp-block-heading\">Should You Add RSC Implementation on Your Roadmap?<\/h2>\n\n\n\n<p>Our verdict? RSCs add a <em>lot<\/em> of value to React development.<\/p>\n\n\n\n<p>They solve some of the most pressing problems with the SSR and CSR approaches: performance, data fetching, and developer experience. <a href=\"https:\/\/www.dreamhost.com\/blog\/best-online-resources-learn-to-code\/\" target=\"_blank\" rel=\"noreferrer noopener\">For developers just starting out with coding<\/a>, this has made life easier.<\/p>\n\n\n\n<p>Now, should you add RSC implementation to your roadmap? We\u2019ll have to go with the dreaded \u2014 <em>it depends<\/em>.<\/p>\n\n\n\n<p>Your app may be working perfectly fine without RSCs. And in this case, adding another layer of abstraction may not do much. However, if you plan to scale, and think RSCs can improve the user experience for your app, try making small changes and scaling from there.<\/p>\n\n\n\n<p>And if you need a powerful server to test RSCs, spin up a <a href=\"https:\/\/www.dreamhost.com\/hosting\/vps\/\" target=\"_blank\" rel=\"noreferrer noopener\">DreamHost VPS<\/a>.<\/p>\n\n\n\n<p>DreamHost offers a fully managed VPS service where you can deploy even your most demanding apps without worrying about maintaining the server.<\/p>\n\n\n\n\n<div class=\"article-cta-shared article-cta-small article-cta--product\">\n\t<div class=\"tr-img-wrap-outer jsLoading\"><img decoding=\"async\" class=\"js-img-lazy \" src=\"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/themes\/blog2018\/assets\/img\/lazy-loading-transparent.webp\" data-srcset=\"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/03\/product-cta-vps-hosting-877x586.webp 1x, https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/03\/product-cta-vps-hosting.webp 2x\"  alt=\"VPS Hosting\" \/><\/div>\n\n\t<a href='https:\/\/www.dreamhost.com\/hosting\/vps\/' class='link-top' target='_blank' rel='noopener noreferrer'>\n\t\t<span>VPS Hosting<\/span>\n\t\t<svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" viewBox=\"0 0 384 512\" width=\"15\"><path d=\"M342.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L274.7 256 105.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z\"\/><\/svg>\n\t<\/a>\n\n\t<div class=\"content-btm\">\n\t\t<h2 class=\"h2--md\">\n\t\t\tWhen You Expect Performance Get DreamHost VPS\n\t\t<\/h2>\n\t\t<p class=\"p--md\">\n\t\t\tBig or small, website or application &#8211; we have a VPS configuration for you.\n\t\t<\/p>\n\n\t\t        <a\n            href=\"https:\/\/www.dreamhost.com\/hosting\/vps\/\"\n                        class=\"btn btn--white-outline btn--sm btn--round\"\n                                    target=\"_blank\"\n            rel=\"noopener noreferrer\"\n            >\n                            See More                    <\/a>\n\n\t<\/div>\n<\/div>","protected":false},"excerpt":{"rendered":"<p>Want to get your head around the basics of React Server Components? Our guide will get you up to speed on when to add them to your roadmap (or not).<\/p>\n","protected":false},"author":1058,"featured_media":48941,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"_yoast_wpseo_metadesc":"Want to get your head around the basics of React Server Components? Our guide will get you up to speed on when to add them to your roadmap (or not).","toc_headlines":"[[\"h-what-are-react-server-components\",\"What Are React Server Components?\"],[\"h2_traditional-react-client-side-rendering-csr\",\"Traditional React: Client-Side Rendering (CSR)\"],[\"h2_the-next-iteration-server-side-rendering-ssr\",\"The Next Iteration: Server-Side Rendering (SSR)\"],[\"h2_finally-the-react-server-components\",\"Finally, the React Server Components\"],[\"h2_should-you-add-rsc-implementation-on-your-roadmap\",\"Should You Add RSC Implementation on Your Roadmap?\"]]","hide_toc":false,"footnotes":""},"categories":[10025],"tags":[],"class_list":["post-48940","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-tech-talk"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v26.3 (Yoast SEO v27.4) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>React Server Components: The Future of React Development - DreamHost<\/title>\n<meta name=\"description\" content=\"Want to get your head around the basics of React Server Components? Our guide will get you up to speed on when to add them to your roadmap (or not).\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Making Sense of React Server Components: A Simple Guide\" \/>\n<meta property=\"og:description\" content=\"Learn about the fundamentals of React Server Components and their potential impact on your projects. Our guide explains when and how to effectively integrate RSCs into your development workflow.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/\" \/>\n<meta property=\"og:site_name\" content=\"DreamHost Blog\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/DreamHost\/\" \/>\n<meta property=\"article:published_time\" content=\"2024-08-28T14:00:00+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-05-22T03:05:07+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/1220x628_ogimage_react_server_components.webp\" \/>\n\t<meta property=\"og:image:width\" content=\"1800\" \/>\n\t<meta property=\"og:image:height\" content=\"942\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/webp\" \/>\n<meta name=\"author\" content=\"Ian Hernandez\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:title\" content=\"Making Sense of React Server Components: A Simple Guide\" \/>\n<meta name=\"twitter:description\" content=\"Learn about the fundamentals of React Server Components and their potential impact on your projects. Our guide explains when and how to effectively integrate RSCs into your development workflow.\" \/>\n<meta name=\"twitter:creator\" content=\"@dreamhost\" \/>\n<meta name=\"twitter:site\" content=\"@dreamhost\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Ian Hernandez\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"8 minutes\" \/>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"React Server Components: The Future of React Development - DreamHost","description":"Want to get your head around the basics of React Server Components? Our guide will get you up to speed on when to add them to your roadmap (or not).","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/","og_locale":"en_US","og_type":"article","og_title":"Making Sense of React Server Components: A Simple Guide","og_description":"Learn about the fundamentals of React Server Components and their potential impact on your projects. Our guide explains when and how to effectively integrate RSCs into your development workflow.","og_url":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/","og_site_name":"DreamHost Blog","article_publisher":"https:\/\/www.facebook.com\/DreamHost\/","article_published_time":"2024-08-28T14:00:00+00:00","article_modified_time":"2025-05-22T03:05:07+00:00","og_image":[{"width":1800,"height":942,"url":"https:\/\/www.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/1220x628_ogimage_react_server_components.webp","type":"image\/webp"}],"author":"Ian Hernandez","twitter_card":"summary_large_image","twitter_title":"Making Sense of React Server Components: A Simple Guide","twitter_description":"Learn about the fundamentals of React Server Components and their potential impact on your projects. Our guide explains when and how to effectively integrate RSCs into your development workflow.","twitter_creator":"@dreamhost","twitter_site":"@dreamhost","twitter_misc":{"Written by":"Ian Hernandez","Est. reading time":"8 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/#article","isPartOf":{"@id":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/"},"author":{"name":"Ian Hernandez","@id":"https:\/\/www-dev.dreamhost.com\/blog\/#\/schema\/person\/220faf2464d5ae08e41cf5f3b28fdc96"},"headline":"React Server Components: The Future of React Development","datePublished":"2024-08-28T14:00:00+00:00","dateModified":"2025-05-22T03:05:07+00:00","mainEntityOfPage":{"@id":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/"},"wordCount":1666,"publisher":{"@id":"https:\/\/www-dev.dreamhost.com\/blog\/#organization"},"image":{"@id":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/#primaryimage"},"thumbnailUrl":"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/1460x1095_blog_hero_react_server_components.webp","articleSection":["Tech Talk"],"inLanguage":"en-US"},{"@type":"WebPage","@id":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/","url":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/","name":"React Server Components: The Future of React Development - DreamHost","isPartOf":{"@id":"https:\/\/www-dev.dreamhost.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/#primaryimage"},"image":{"@id":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/#primaryimage"},"thumbnailUrl":"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/1460x1095_blog_hero_react_server_components.webp","datePublished":"2024-08-28T14:00:00+00:00","dateModified":"2025-05-22T03:05:07+00:00","description":"Want to get your head around the basics of React Server Components? Our guide will get you up to speed on when to add them to your roadmap (or not).","breadcrumb":{"@id":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/#primaryimage","url":"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/1460x1095_blog_hero_react_server_components.webp","contentUrl":"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2024\/08\/1460x1095_blog_hero_react_server_components.webp","width":2190,"height":1643,"caption":"React Server Components: The Future of React Development"},{"@type":"BreadcrumbList","@id":"https:\/\/www-dev.dreamhost.com\/blog\/react-server-components\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/dhblog.dream.press\/blog\/"},{"@type":"ListItem","position":2,"name":"React Server Components: The Future of React Development"}]},{"@type":"WebSite","@id":"https:\/\/www-dev.dreamhost.com\/blog\/#website","url":"https:\/\/www-dev.dreamhost.com\/blog\/","name":"DreamHost Blog","description":"","publisher":{"@id":"https:\/\/www-dev.dreamhost.com\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www-dev.dreamhost.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/www-dev.dreamhost.com\/blog\/#organization","name":"DreamHost","url":"https:\/\/www-dev.dreamhost.com\/blog\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www-dev.dreamhost.com\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/dhblog.dream.press\/blog\/wp-content\/uploads\/2019\/01\/dh_logo-blue-2.png","contentUrl":"https:\/\/dhblog.dream.press\/blog\/wp-content\/uploads\/2019\/01\/dh_logo-blue-2.png","width":1200,"height":168,"caption":"DreamHost"},"image":{"@id":"https:\/\/www-dev.dreamhost.com\/blog\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/www.facebook.com\/DreamHost\/","https:\/\/x.com\/dreamhost","https:\/\/www.instagram.com\/dreamhost\/","https:\/\/www.linkedin.com\/company\/dreamhost\/","https:\/\/www.youtube.com\/user\/dreamhostusa"]},{"@type":"Person","@id":"https:\/\/www-dev.dreamhost.com\/blog\/#\/schema\/person\/220faf2464d5ae08e41cf5f3b28fdc96","name":"Ian Hernandez","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2022\/04\/ian-hernandez-dreamhost-150x150.png","url":"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2022\/04\/ian-hernandez-dreamhost-150x150.png","contentUrl":"https:\/\/www-dev.dreamhost.com\/blog\/wp-content\/uploads\/2022\/04\/ian-hernandez-dreamhost-150x150.png","caption":"Ian Hernandez"},"description":"Ian is a Product Designer based in Los Angeles, California. He is responsible for driving brand and product design at DreamHost, developing and maintaining our internal design system, and writing frontend code when he can. In his free time, he enjoys walking his dog, learning history, and discovering new music online and irl. Connect with him on LinkedIn: https:\/\/www.linkedin.com\/in\/ianhernandez23\/","url":"https:\/\/www-dev.dreamhost.com\/blog\/author\/ianh\/"}]}},"lang":"en","translations":{"en":48940,"es":48920,"ru":50735,"pt":54931,"uk":54946,"de":54958,"pl":54981,"it":68387,"fr":70369,"nl":70399},"pll_sync_post":[],"_links":{"self":[{"href":"https:\/\/www-dev.dreamhost.com\/blog\/wp-json\/wp\/v2\/posts\/48940","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www-dev.dreamhost.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www-dev.dreamhost.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www-dev.dreamhost.com\/blog\/wp-json\/wp\/v2\/users\/1058"}],"replies":[{"embeddable":true,"href":"https:\/\/www-dev.dreamhost.com\/blog\/wp-json\/wp\/v2\/comments?post=48940"}],"version-history":[{"count":5,"href":"https:\/\/www-dev.dreamhost.com\/blog\/wp-json\/wp\/v2\/posts\/48940\/revisions"}],"predecessor-version":[{"id":49481,"href":"https:\/\/www-dev.dreamhost.com\/blog\/wp-json\/wp\/v2\/posts\/48940\/revisions\/49481"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www-dev.dreamhost.com\/blog\/wp-json\/wp\/v2\/media\/48941"}],"wp:attachment":[{"href":"https:\/\/www-dev.dreamhost.com\/blog\/wp-json\/wp\/v2\/media?parent=48940"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www-dev.dreamhost.com\/blog\/wp-json\/wp\/v2\/categories?post=48940"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www-dev.dreamhost.com\/blog\/wp-json\/wp\/v2\/tags?post=48940"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}