React is the most popular front-end framework for its modular design and easy-to-code declarative approach. However, vanilla React does not score well on the SEO scorecard. Techniques like Pre-rendering let us optimize React apps for SEO. Also, new frameworks like Next.js and Gatsby build on the power of isomorphic JavaScript (more on that later) to give us the twin benefits of React’s speed and ease of use with robust SEO and UX performance.
The Problem – Why Vanilla React Does Not Score Well on SEO
Let us quickly look at how Google Bot ( and other search engines) index websites before addressing React SEO's problem.
How Search Index Crawlers Work – A Quick Look
Search Engines crawlers roam over the Internet to gather information about websites to store it in their database. Users can only discover your site on search engine results if the crawler stores or "indexes" this information. The modern web is vast, with millions of websites and billions of pages. So, crawlers have to get the best performance with minimum resources.
Because of these constraints, crawlers are optimized for HTML data and index HTML values first when they visit your website. Processing JavaScript is a costly operation for crawlers, and they allot it a lower priority. So, if your website does not serve meaningful HTML data quickly, they will jump to the next site.
React follows a declarative approach and does not send meaningful HTML documents as first responses to requests. Instead, it only tells what to render, and the browser runs the JavaScript to render the actual HTML. As React delivers no semantically rich HTML, web crawlers cannot easily index sites made of pure React.Because of this design choice, React has these SEO challenges:
Empty First Pages
As we saw above, the initial loads in React are not info-rich HTML pages. So, crawlers cannot know what the site or page is about and do not readily index it.
Slow Load Times and UX Issue
React needs the browser to run JavaScript to render all UI elements. Processing JavaScript snippets is a slow operation and might even need multiple network calls. So, simple React apps have slow load times. Besides, the heavy JavaScript processing does not provide an optimum user experience. Google Bot penalizes both these factors when it indexes your site, causing you costly SEO point hits.
Metadata tags
Google, social networks, and other content sharing platforms use your page’s metadata to display information like descriptions, titles, and image data for better click-through rates. But, React only renders these meta tags in the browser on the client machine. So, these content sharing sites cannot list your pages correctly, leading to traffic loss and poor SEO performance.
React Does not Have an In-Built Sitemap Functionality.
A sitemap is a blueprint of your site that helps Google Bot understand its structure and relations between different pages. All this helps the crawler index your website better. But, React does not have an in-built sitemap generating functionality. You might use some third-party tools, but the process can be complex.
The Solution – Use the Power of Isomorphic React for Universal Apps
Modern React provides us with an easy fix for the original SEO challenge with React. We use isomorphic JavaScript in React to write the same code for both the server and the client. Such apps have mixed render paths split over both the client and server-side and are called universal apps.
When we use isomorphic React, we can send info-rich HTML pages to web crawlers to help them index our site better. Also, we can choose between several render path options to decide how much information we want to send in the initial HTML first load. After the first load, isomorphic React apps behave as client-rendering apps, and we can dynamically update content with JavaScript.
New frameworks like Next.js and Gatsby let us write isomorphic React code quickly by hiding away its complexity. We can choose one of these render paths to optimize our site for SEO as per our specific use case:
Server-Side Rendering to Static Content (SRSS)
If your site needs to generate HTML content based on user input but only needs to deliver the static page in response, you can use server-side rendering to static content. Your server will manage the routes, generate the user-specific static HTML content, and then serve it quickly to the browser. React provides you with the renderToStaticMarkup method for doing this.
Server Side Rendering with Rehydration (SSRH)
Like SRSS, SSRH adds rehydration to the mix to provide full JavaScript-based dynamic content ability to your app after the static first load. You can quickly load the initial static semantically rich HTML document to optimize it for SEO and user experience. After that, your app behaves like a complete-fledged client-rendered application. Then, you can dynamically update the UI with JavaScript processing.
Pre-Rendering to Specific Content (PRS)
PRS takes Server Side Rendering one notch up by pre-building static HTML pages and delivering them super-fast as initial loads. We can achieve fantastic load times with PRS and provide semantically rich initial static pages to optimize them perfectly for SEO. An ideal use-case for PRS is e-commerce site product pages which generally do not depend on user input for their content but need fast load times for higher conversions.
Pre-Rendering with Hydration (PRH)
Finally, pre-rendering with hydration lets us update dynamic content in the UI after the initial pre-rendered static HTML page. This technique builds on PRH to provide a full-blown React app after the initial page load.
Each of the render paths is best for specific use cases. For example, in terms of pure load times, PRS performs best, but SSRH may be a better option for a rich web application where a user lands on his profile page.
The key takeaway is that modern React provides many options to optimize our website for SEO and superior performance. By choosing smartly as per the use case, you can now achieve excellent SEO results with your React websites.
FAQs:
-
Is React good for SEO?
While SEO is not one of the goals of React, modern React provides us with many features to achieve superior SEO performance. You should read our guide above to get the best React SEO results. -
Which rendering is best?
You should choose a rendering method that aligns with the goals of your application. You should read our in-depth guide on rendering methods (internal link to rendering article here) to find out what best suits your site. -
Why should I optimize my React app for SEO?
You can only grow your React app’s human user base if they can discover it. For this, you need to optimize your React app for SEO to let Google and other search engines show it up in their search results.