Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vinaygopinath/ng2-meta
Dynamic meta tags and SEO in Angular2
https://github.com/vinaygopinath/ng2-meta
Last synced: 2 months ago
JSON representation
Dynamic meta tags and SEO in Angular2
- Host: GitHub
- URL: https://github.com/vinaygopinath/ng2-meta
- Owner: vinaygopinath
- License: mit
- Created: 2016-07-21T23:25:33.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2018-07-03T16:19:38.000Z (over 6 years ago)
- Last Synced: 2024-04-13T21:57:40.567Z (9 months ago)
- Language: TypeScript
- Size: 85 KB
- Stars: 200
- Watchers: 14
- Forks: 44
- Open Issues: 15
-
Metadata Files:
- Readme: README.MD
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-angular-components - ng2-meta - Dynamic meta tags and SEO in Angular2. (Uncategorized / Uncategorized)
- awesome-angular-components - ng2-meta - Dynamic meta tags and SEO in Angular2 (Uncategorized / Uncategorized)
- awesome-angular-components - ng2-meta - Dynamic meta tags and SEO in Angular2. (Uncategorized / Uncategorized)
README
# ng2-meta
[![Join the chat at https://gitter.im/ng2-meta/Lobby](https://badges.gitter.im/ng2-meta/Lobby.svg)](https://gitter.im/ng2-meta/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
Update HTML meta tags for title, description and others automatically based on the route in your Angular app.
ng2-meta v5.0.0+ requires **Angular 6**.
On **Angular 5** or lower, use ng2-meta v4.0.0 (`npm install [email protected]`)For the AngularJS (1.x) module, check out [ngMeta](https://github.com/vinaygopinath/ngMeta)
## Getting started
### Install
To install this library, run:```bash
$ npm install ng2-meta --save
```### Modify routes
Add meta tags and `MetaGuard` to routes. By default, `title` and `description` values are duplicated for `og:title` and `og:description`, so there's no need to add them separately.
import { MetaGuard } from 'ng2-meta';const routes: Routes = [
{
path: 'home',
component: HomeComponent,
canActivate: [MetaGuard],
data: {
meta: {
title: 'Home page',
description: 'Description of the home page'
}
}
},
{
path: 'dashboard',
component: DashboardComponent,
canActivate: [MetaGuard],
data: {
meta: {
title: 'Dashboard',
description: 'Description of the dashboard page',
'og:image': 'http://example.com/dashboard-image.png'
}
}
}
];### Import MetaModule
...
import { MetaModule } from 'ng2-meta';@NgModule({
declarations: [
AppComponent,
...
],
imports: [
BrowserModule,
FormsModule,
HttpModule,
RouterModule.forRoot(routes),
MetaModule.forRoot()
],
bootstrap: [AppComponent]
})### Update AppComponent
import { MetaService } from 'ng2-meta';@Component({
...
})
export class AppComponent {
constructor(private metaService: MetaService) {}
}You're all set! ng2-meta will update the meta tags whenever the route changes.
## Options
### Set defaults
Set default values for tags. These values are used when routes without `meta: {}` information are encountered.
```typescript
import { MetaConfig, MetaService } from 'ng2-meta';const metaConfig: MetaConfig = {
//Append a title suffix such as a site name to all titles
//Defaults to false
useTitleSuffix: true,
defaults: {
title: 'Default title for pages without meta in their route',
titleSuffix: ' | Site Name',
'og:image': 'http://example.com/default-image.png',
'any other': 'arbitrary tag can be used'
}
};@NgModule({
declarations: [
AppComponent,
...
],
imports: [
...,
MetaModule.forRoot(metaConfig)
],
bootstrap: [AppComponent]
})```
### Change meta tags programmatically
```typescript
import { Component, OnInit } from '@angular/core';class ProductComponent implements OnInit {
...
constructor(private metaService: MetaService) {}ngOnInit() {
this.product = //HTTP GET for product in catalogue
this.metaService.setTitle('Product page for '+this.product.name);
this.metaService.setTag('og:image',this.product.imageURL);
}
}
```### Define fallback meta content in HTML
While Google executes Javascript and extracts meta tags set by ng2-meta, many bots (like Facebook and Twitter) do not execute Javascript. Consider defining fallback meta tags in your HTML for such bots. The fallback content is overridden by ng2-meta in Javascript-enabled environments.```html
```
## Contribute
If you wish to contribute to this repo, please check out the [open issues](https://github.com/vinaygopinath/ng2-meta/issues).
If you notice a bug that has not already been reported or would like to make a feature request, please create a [new issue](https://github.com/vinaygopinath/ng2-meta/issues/new). This helps to start a discussion with the community and avoid duplication of effort before you make any changes.
## Licence
MIT © [Vinay Gopinath](http://vinaygopinath.me)