Don*_*nie 8 angular-routing angular
目标
在不失去理智的情况下使路由工作.
错误
Error: Can't resolve all parameters for Router: (?, ?, ?, ?, ?, ?, ?, ?)
Run Code Online (Sandbox Code Playgroud)
app.routing.ts
import { ModuleWithProviders } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { NavbarComponent } from './navbar/navbar.component';
import { CustomerComponent } from './customer/customer.component';
export const appRoutes: Routes = [
{ path: '', redirectTo: 'customers', pathMatch: 'full' },
{ path: 'customers', component: CustomerComponent },
];
export const routing: ModuleWithProviders = RouterModule.forRoot(appRoutes);
Run Code Online (Sandbox Code Playgroud)
app.module.ts
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { BrowserModule } from '@angular/platform-browser';
import { routing } from './app.routing';
import { AppComponent } from './app.component';
import { NavbarComponent } from './navbar/navbar.component';
import { CustomerComponent } from './customer/customer.component';
@NgModule({
imports: [
BrowserModule,
FormsModule,
routing
],
declarations: [
AppComponent,
NavbarComponent,
CustomerComponent,
],
providers: [
// ...
],
bootstrap: [ AppComponent ]
})
export class AppModule {
// ...
}
Run Code Online (Sandbox Code Playgroud)
app.component.ts
import { RouterLink } from '@angular/router';
import { HTTP_PROVIDERS } from '@angular/http';
import { Component } from '@angular/core';
import { NavbarComponent } from './navbar/navbar.component';
import { CustomerComponent } from './customer/customer.component';
export { Config } from './config/env.config';
@Component({
moduleId: module.id,
selector: 'app',
templateUrl: 'app.component.html',
styleUrls: ['app.component.css'],
directives: [NavbarComponent, CustomerComponent],
providers: [HTTP_PROVIDERS, RouterLink]
})
export class AppComponent
{
constructor() {
// console.log('Environment config', Config);
}
ngOnInit() {
// ...
}
}
Run Code Online (Sandbox Code Playgroud)
navbar.component.ts
import { Router, ROUTER_DIRECTIVES } from '@angular/router';
import { Component } from '@angular/core';
@Component({
moduleId: module.id,
selector: 'navbar',
templateUrl: 'navbar.component.html',
styleUrls: ['navbar.component.css'],
directives: [ROUTER_DIRECTIVES],
providers: [Router],
})
export class NavbarComponent
{
version: string;
versionIsVisible: boolean;
constructor() {
this.version = '<%= VERSION %>';
}
ngOnInit() {
// ...
}
}
Run Code Online (Sandbox Code Playgroud)
app.component.html
<navbar></navbar>
<router-outlet></router-outlet>
Run Code Online (Sandbox Code Playgroud)
navbar.component.html
<a routerLink="/customers">Customers</a>
Run Code Online (Sandbox Code Playgroud)
小智 8
现在欣赏旧帖子,但我有同样的问题,刚刚解决了它.
该错误建议Angular无法解析Router类的某些依赖项.
navbar.component.ts
import { Router, ROUTER_DIRECTIVES } from '@angular/router';
import { Component } from '@angular/core';
@Component({
moduleId: module.id,
selector: 'navbar',
templateUrl: 'navbar.component.html',
styleUrls: ['navbar.component.css'],
directives: [ROUTER_DIRECTIVES],
providers: [Router],
})
Run Code Online (Sandbox Code Playgroud)
我通过不将路由器注入提供程序来修复此问题,并且仅注入构造函数,因此最终得到:
@Component({
moduleId: module.id,
selector: 'navbar',
templateUrl: 'navbar.component.html',
styleUrls: ['navbar.component.css'],
directives: [ROUTER_DIRECTIVES]
})
export class NavbarComponent
{
version: string;
versionIsVisible: boolean;
constructor(private _router: Router) {
this.version = '<%= VERSION %>';
}
ngOnInit() {
// ...
}
}
Run Code Online (Sandbox Code Playgroud)
我是angular2的新手,所以我无法给你一个详细的理由!
| 归档时间: |
|
| 查看次数: |
11747 次 |
| 最近记录: |