A website built with AngularJS loads all of its content on a single page. Its template remains unchanged, only the copy reloads to display the information a visitor requested.
I admit that the concept is fabulous. Having a single page application means almost instantaneous loading time – not to mention, easier development and fewer code errors to fix.
There is one problem, though: optimizing AngularJS for SEO.
Angular apps serve content on the client-side. Because of that, they strip a page from all the elements Google needs to crawl and index to rank a page.
Can SEOs do anything about it, or should they give up and leave any AngularJS pages on the site unoptimized?
No, absolutely not! For one, you can actually optimize AngularJS. Granted, it requires some technical SEO know how, but it can be done.
Before I tell you more about it, let's take a look at the basics first.
What is AngularJS?
The definition can sound a bit cryptic to anyone unaccustomed to coding and web technologies, so let's break it down to understand it better.
- HTML defining the content on the page,
- CSS used to style and position the content and other page elements, and
An Angular-based website doesn’t store individual pages as separate files. Instead, it loads the content users request on the client side via a single application. This means that instead of loading a new page to display different content, it just replaces it on the same page.
That's why these web properties are often called Single Page Applications (SPAs).
In practical terms, the difference means that, instead of rendering a new page every time a user requests information, all interaction with the content happens on the same page through AJAX calls.
Why Use AngularJS?
Building websites with the Angular framework has three main benefits:
- Content loads much faster on a single page application since there is no need to load a new HTML code every time. This results in a far better user experience.
- As a result of the above, developers make fewer mistakes, which results in fewer users who encounter problems when browsing the site. Technical teams don’t have to spend time revisiting their code to fix mistakes. A win-win scenario for everyone.
Unfortunately, however, Angular presents some major challenges for SEO.
Why is AngularJS So Challenging for SEO?
- Then, it renders whatever JS content is on the page and indexes it accordingly.
For one, by calling content via API connections, the single-page technology removes all crawlable content from the page’s actual code. The time frame for the API connections to populate content within the DOM becomes important, as you want to ensure that is the threshold for Google to view the content.
Unlike a traditional HTML page containing all website content, an SPA will only include the basic page structure. The actual wording, however, appears through a dynamic API call.
For SEO, the above means that a page contains no actual HTML in the source code. As a result, all the elements Google would crawl are not there. If you were to view the source code or review a Google cache during this time frame, what you will see is a blank page.
Moreover, search engines cannot cache SPAs either. The two visuals below illustrate this problem well. The top one shows what a user sees when visiting an Angular page. The other presents the actual content Google can access and crawl.
What the user sees:
What Google caches:
A stark difference, isn’t it?
For users, the page works like any other. They can navigate the site easily. They can access, read and interact with the information.
Google, on the other hand, sees hardly anything on the page. Certainly, not enough to even index it properly.
That’s the challenge SEOs face with Angular apps. Such applications lack everything that’s needed to rank them well.
Luckily, there’s good news, too.
How to Optimize AngularJS Applications for Google Crawling
There are a couple ways to ensure that your site can be crawled cleanly.
Use Google CodeLab and utilize #PushState to change the URL
Google's CodeLab walks developers through the most important SEO elements that will need to render on a page. This includes utilizing #PushState and the History API to change the URL, adding in important elements on-page or via the DOM (meta title, descriptions, canonical tags, etc.), making sure all internal links are shown within the code base (and not as on-click events), and dynamically loading in content.
The biggest issue with this method is that the time to render the content may be higher. And while this will load some of the necessary SEO elements, it's not always easy to ensure that the content also appears on site to its fullest ability. Also, if you utilize this method then you also need to customize your analytics metrics to make sure it is also recording each visit as a unique visit and page view.
Server-side rendering with Angular Universal
A viable option, however, involves using Angular Universal extension to create static versions of pages to be rendered server-side. Needless to say, these are fully indexable by Google.
Dynamic rendering is a preferred option by creating a flat HTML version of your site and using that version to submit to Google for crawling and rendering. According to Google's own website, "Googlebot generally doesn't consider dynamic rendering as cloaking. As long as your dynamic rendering produces similar content, Googlebot won't view dynamic rendering as cloaking." This offers sites the opportunity to create an extremely fast version of their sites for crawling and indexing while allowing front end designers the luxury of adding whatever elements they would like to improve the user experience. Depending on the technology stack that a site is using, the idea of creating a separate version saves production time, and allows the internal team to focus on developing front end solutions while the SEO technical team can outsource the render to be created.
There are services including Prerender.io, that will create cached versions of the content and render it in a form that Googlebot can crawl and index. The down side of utilizing Prerender.io is that there are costs added both to create the render and then also based on the amount of pages that you have on your site, the cost can escalate pretty quickly. Newer services like huckabuy.com offer to create a static pre-render of your site that is already optimized with Schema markup. Google also offers a solution using Renderton which is an open source Codelab based on headless Chromium.
The one issue with pre-rendering your site is that Google can depreciate it easily, leaving the site without an indexable solution again. However, most experts in the industry believe that Google will continue to support this option and actually may list it as its preferred method since it would allow them to speed up the process of crawling and rendering site content. In Google's documentation, they have updated their recommendations to include dynamic rendering as a solution.
Initial Static Rendering
Unfortunately, once again, the solution might prove insufficient at times depending on the resources loaded and the speed and doesn't always align with Googlebot crawler behavior.
How to Prepare for Server-Side Rendering with the Angular Universal Extension
Below is a brief overview of the process from the Angular’s official site. Before going through the process, though, I recommend you move to a controlled testing environment.
Prepare your app by modifying both the app code and its configuration.
Add a build target, and build a Universal bundle using the CLI with the @nguniversal/express-engine schematic.
Set up a server to run Universal bundles.
Pack and run the app on the server.
The result? A cached page that looks like this:
Granted, it’s not visually striking. A user wouldn’t see it, though. The search engine, however, would find all the information it needs to crawl and index the page properly, which is exactly your objective.
When a client made the move to AngularJS this created an issue in terms of overall search visibility. Our team provided a remediation strategy to ensure the site was visible to search engines. The team continued to have AngularJS issues and needed steps for execution to boost competitive visibility, traffic and revenue from organic search. Our team recommended a remediation strategy and QA'd the execution by their internal teams with static site rendering and the client saw a 54% increase in #1 rankings and 43% increase in top 3 rankings within the first month post-launch.
Another client had just implemented AngularJS and began to see their site traffic rapidly decline 25% YoY as a result. The client implemented dynamic rendering of page titles, meta descriptions and H1 tags with pre-render I/O caching. Our team provided a remediation plan and QA'd the execution. Top 3 rankings grew 55% and Top 10 grew 29% 90-days post-launch. Overall traffic grew 34% YoY 90-days post-launch.
AngularJS offers incredible opportunities to improve user experience and cut the development time. Unfortunately, it also causes serious challenges for SEO.
For one, single-page applications contain no code elements required to have the content crawled and indexed for rankings.
Luckily, SEOs can overcome it with these options:
Use dynamic rendering with a platform, like Prerender.io or Huckabuy.
Creating an AngularJS and HTML hybrid called Initial Static Rendering.
- Use Google CodeLab to add the essential items for indexing.
Using Angular Universal extension to create static versions of the site for crawling and indexing.
For Angular specifically, Angular Universal may offer the optimal solution. For sites that want to continue to enhance their site and not be restricted to Angular alone, then dynamic rendering offers the best solution. Whichever method you choose, you will want to work through the process hand in hand with a development team experienced in working with clients to optimize their website. Our team at seoClarity is well-versed in making recommendations and providing QA testing for teams regardless of the solution.
Editor's Note: This post was originally published in March 2019 and has been updated for accuracy and comprehensiveness.