【问题标题】:Angular 2 RC5 EXCEPTION: Error: Uncaught (in promise): Cannot resolve component using 'HomeComponent'Angular 2 RC5 例外:错误:未捕获(承诺):无法使用“HomeComponent”解析组件
【发布时间】:2019-02-11 11:04:06
【问题描述】:

我正在尝试我的 abgular2 RC5 路由功能,请看下面的代码。

app.component.ts

import { Component,HostBinding } from '@angular/core';
import { ROUTER_DIRECTIVES } from "@angular/router";

@Component({
selector: 'my-app',
template: `
<h1>My First Angular 2 App </h1>  
<router-outlet></router-outlet>
`
})
export class AppComponent {}

import { Component } from '@angular/core';

usercomp.ts

@Component({
selector: 'user-comp',
template: `    
<h1>USER COMPONENT</h1>
`
})
export class UserComponent {}

homecomponent.ts

import { Component } from '@angular/core';

@Component({
moduleId: module.id,
selector: 'home-component',
template: `
<h1>Home Component</h1>
`
})
export class HomeComponent {}

app.module.ts

 import { NgModule }      from '@angular/core';
 import { BrowserModule } from '@angular/platform-browser';
 import { Component } from '@angular/core';
 import { AppComponent }  from './app.component';
 import { routing } from './approuter'
 import { ROUTER_DIRECTIVES } from '@angular/router'
 import { HomeComponent } from './homecomponent'
 import { UserComponent } from './usercomp'

 @NgModule({
   imports:      [ BrowserModule,routing ],
   declarations: [ AppComponent,HomeComponent,UserComponent ],
   bootstrap:    [ AppComponent ]
  })
 export class AppModule { }

approuter.ts

   import { RouterModule,Routes } from '@angular/router'

  const APP_ROUTES:Routes = [
    {
    path:'user',
    component:'UserComponent'
   },
   {
    path:'',
    component:'HomeComponent'
   }

   ];

    export const routing = RouterModule.forRoot(APP_ROUTES);

错误

我尝试在任何地方导出 HomeComponent 和 UserComponent 主组件,但无法摆脱此代码。使用 RC4,它在旧的方式中运行良好,但不确定我在这里做错了什么,请看一下,当我出错时让我知道..

【问题讨论】:

  • 请提供approuter的实现
  • 可以加approuter.ts吗?
  • 抱歉我的更新不好..
  • @Nomad 与this question 相同
  • @Pankaj Parkar 虽然在发布这个问题之前我做了很好的谷歌搜索,但不知道为什么这个问题没有出现..

标签: angular typescript


【解决方案1】:
   import { RouterModule,Routes } from '@angular/router'
   import { HomeComponent } from './homecomponent';
   import { UserComponent } from './usercomp';

   const APP_ROUTES:Routes = [
       {
           path:'user',
           component: UserComponent
       },
       {
           path:'',
           component: HomeComponent
       }
   ];

    export const routing = RouterModule.forRoot(APP_ROUTES);

component 接受任何组件类型,请查看类参考here

【讨论】:

  • 好的,您是否尝试使用我提供的上述代码更改您的 approuter.ts 文件?,您不应该像在实现中那样为组件属性提供字符串,您需要提供它一个组件类型。将我的代码复制粘贴到 approuter.ts 文件中的代码上
【解决方案2】:

我认为您需要将 pathMatch 添加到您的默认路由:

{ path: '', redirectTo: '/home', pathMatch: 'full'  },
{ path: 'home',  loadChildren: './app/home/home.module#HomeModule' }

【讨论】:

    猜你喜欢
    • 2017-02-17
    • 1970-01-01
    • 2020-03-03
    • 1970-01-01
    • 1970-01-01
    • 2017-08-14
    • 2019-10-07
    • 2019-10-13
    • 1970-01-01
    相关资源
    最近更新 更多