在Angular 6中,预渲染(用于SEO)可能无法将routerLink转换为Href。这是因为预渲染是在服务器上进行的,而不是在浏览器中进行的,因此无法执行Angular的路由器逻辑。解决此问题的一种方法是使用Angular的解析器来手动转换routerLink为Href。
下面是一个示例解决方案:
import { Injectable } from '@angular/core';
import { LocationStrategy } from '@angular/common';
@Injectable()
export class PrerenderService {
constructor(private locationStrategy: LocationStrategy) {}
getHref(url: string): string {
const baseUrl = this.locationStrategy.getBaseHref();
return baseUrl + url;
}
}
import { Component } from '@angular/core';
import { PrerenderService } from './prerender.service';
@Component({
selector: 'app-my-component',
template: `
Link
`,
})
export class MyComponent {
constructor(public prerenderService: PrerenderService) {}
}
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { LocationStrategy, PathLocationStrategy } from '@angular/common';
import { PrerenderService } from './prerender.service';
@NgModule({
imports: [BrowserModule],
declarations: [AppComponent],
providers: [
{ provide: LocationStrategy, useClass: PathLocationStrategy },
PrerenderService,
],
bootstrap: [AppComponent],
})
export class AppModule {}
通过这种方式,你可以在预渲染时将routerLink转换为Href,以便在SEO期间正确显示链接。