Optimizing Angular Universal for SEO

โœ๏ธ

Optimize Angular Universal for SEO by including a title and meta descriptions

16 Feb, 2021 ยท 3 min read

Today we will be continuing our journey to convert our existing Angular application into Angular Universal.

And one of the reasons we want this is SEO. That is where the title and meta service come in super handy. They can help us set the title and meta descriptions for pages, not just at runtime but on the server-side level.

Meaning all bots can read what we want them to read.

For the result, we should open the source code of a page and see the title and meta description we provided.

Angular Universal title and meta description

Adding a title to our Angular component

Let's start by opening up our welcome.component.ts. This will be our testing ground. Since it's not the main page, we should quickly see the results while viewing the page source.

We start by importing the Title service into our component.

import { Title } from '@angular/platform-browser';

The next part is to inject the titleService into our constructor.

constructor(private titleService: Title) { }

Now we can use the titleService throughout this component.

We will use the ngOnInit function to set the title.

ngOnInit(): void {
  this.titleService.setTitle('Welcome to my Angular app');
}

Now let's test it by running our app in Universal.

npm run build:ssr && npm run serve:ssr

Open the browser and visit our welcome page. We should see the title come into action:

Angular Title

But the main goal is that it is now adjusted on the server-rendered version, so let's inspect the page source.

Angular Title in source code

Yes, we got it, this is something crawlers and bots can read ๐Ÿคฉ.

Adding meta tags to our Angular component

With the title working, we can look at tags. The Meta service allows us to create all kinds of cool tags. We will be focussing on the Meta tags today.

First, let's start by importing the Meta service.

import { Title, Meta } from '@angular/platform-browser';

Then let's make it available to the component in the constructor.

constructor(private titleService: Title, private metaService: Meta) {}

And like we've seen with the title service, we can now call this in the ngOnInit. Let's set a meta description and some tags.

this.metaService.addTags([
  { name: 'keywords', content: 'Welcome, Hello' },
  {
    name: 'description',
    content:
      'We would like to welcome you to the wonderful world of Angular Universal',
  },
]);

Let's try it out by running our app once again:

npm run build:ssr && npm run serve:ssr

Now we can expect our head and see if the meta tags are injected:

Angular Universal meta description

And there you go, you now have the power to inject meta descriptions and titles in the server-side rendered application. This will help crawlers and bots index your website correctly.

You can find today's source code on GitHub.

Thank you for reading, and let's connect!

Thank you for reading my blog. Feel free to subscribe to my email newsletter and connect on Facebook or Twitter

Spread the knowledge with fellow developers on Twitter
Tweet this tip
Powered by Webmentions - Learn more

Read next ๐Ÿ“–

Angular dynamic classes using ngClass

31 Mar, 2021 ยท 2 min read

Angular dynamic classes using ngClass

Angular dynamically change form validators

30 Mar, 2021 ยท 3 min read

Angular dynamically change form validators