首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Angular2 -链路中的路由“[‘名称’]”不解析到终端指令

Angular2 -链路中的路由“[‘名称’]”不解析到终端指令
EN

Stack Overflow用户
提问于 2015-12-16 16:54:04
回答 1查看 6.8K关注 0票数 16

我试图得到一个简单的应用程序与子路由。

当我在子组件上设置路由时,会收到以下错误消息:

代码语言:javascript
复制
Link "["ChildItem"]" does not resolve to a terminal instruction

如果我将所有路由放置在父组件上,它将正确工作。如果在子组件和父组件之间拆分路由,则会得到上述错误。

它与同一组件上的所有路由一起工作:

代码语言:javascript
复制
import {bootstrap} from 'angular2/platform/browser';
import {Component, provide} from 'angular2/core';
import {COMMON_DIRECTIVES, CORE_DIRECTIVES, FORM_DIRECTIVES, NgFor, NgIf} from 'angular2/common';
import {ROUTER_DIRECTIVES, ROUTER_PROVIDERS, RouteConfig, RouterLink, RouterOutlet, Route, LocationStrategy, HashLocationStrategy} from 'angular2/router';


@Component({selector: 'subItem1',template: `SubItem1`})export class SubItem1{}
@Component({selector: 'subItem2',template: `SubItem2`})export class SubItem2{}
@Component({selector: 'subItem3',template: `SubItem3`})export class SubItem3{}

@Component({
    selector: 'childItem',
    directives: [COMMON_DIRECTIVES, CORE_DIRECTIVES, ROUTER_DIRECTIVES, RouterLink],
    template: `<h2>Child Item</h2>
    <ul>
    <li><a [routerLink]="['/SubItem1']">SubItem1</a></li>
    <li><a [routerLink]="['/SubItem2']">SubItem2</a></li>
    <li><a [routerLink]="['/SubItem3']">SubItem3</a></li>
    </ul>
    `
})  
export class ChildItem{}


@Component({
    selector: 'home',
    directives: [COMMON_DIRECTIVES, CORE_DIRECTIVES, ROUTER_DIRECTIVES, RouterLink],
    template: `<h2>Home page</h2>
    <a [routerLink]="['/ChildItem']">Click Me</a>`
})
export class Home{}


@Component({
  selector: 'my-app',
  template: `<h1>Routing Test</h1>
  <router-outlet></router-outlet>`,
  directives: [ROUTER_DIRECTIVES, RouterLink, RouterOutlet]
})
@RouteConfig([
        { path: '/', component: Home, as: 'Home' },
        { path: '/child', component: ChildItem, as: 'ChildItem' },
        { path: '/child/1/', component: SubItem1, as: 'SubItem1' },
        { path: '/child/2/', component: SubItem2, as: 'SubItem2' },
        { path: '/child/3/', component: SubItem3, as: 'SubItem3' }
])
export class AppComponent {}

    bootstrap(AppComponent, [ROUTER_PROVIDERS, provide(LocationStrategy, { useClass: HashLocationStrategy })])

下面是在不同组件上的路由,在这些路径中,当我查看“子组件”时会得到错误:

代码语言:javascript
复制
import {bootstrap} from 'angular2/platform/browser';
import {Component, provide} from 'angular2/core';
import {COMMON_DIRECTIVES, CORE_DIRECTIVES, FORM_DIRECTIVES, NgFor, NgIf} from 'angular2/common';
import {ROUTER_DIRECTIVES, ROUTER_PROVIDERS, RouteConfig, RouterLink, RouterOutlet, Route, LocationStrategy, HashLocationStrategy} from 'angular2/router';


@Component({selector: 'subItem1',template: `SubItem1`})export class SubItem1{}
@Component({selector: 'subItem2',template: `SubItem2`})export class SubItem2{}
@Component({selector: 'subItem3',template: `SubItem3`})export class SubItem3{}

@Component({
    selector: 'childItem',
    directives: [COMMON_DIRECTIVES, CORE_DIRECTIVES, ROUTER_DIRECTIVES, RouterLink],
    template: `<h2>Child Item</h2>
    <ul>
    <li><a [routerLink]="['/SubItem1']">SubItem1</a></li>
    <li><a [routerLink]="['/SubItem2']">SubItem2</a></li>
    <li><a [routerLink]="['/SubItem3']">SubItem3</a></li>
    </ul>
    `
})
@RouteConfig([
        { path: '/1', component: SubItem1, as: 'SubItem1' },
        { path: '/2/', component: SubItem2, as: 'SubItem2' },
        { path: '/3/', component: SubItem3, as: 'SubItem3' }
])
export class ChildItem{}


@Component({
    selector: 'home',
    directives: [COMMON_DIRECTIVES, CORE_DIRECTIVES, ROUTER_DIRECTIVES, RouterLink],
    template: `<h2>Home page</h2>
    <a [routerLink]="['/ChildItem']">Click Me</a>`
})
export class Home{}


@Component({
  selector: 'my-app',
  template: `<h1>Routing Test</h1>
  <router-outlet></router-outlet>`,
  directives: [ROUTER_DIRECTIVES, RouterLink, RouterOutlet]
})
@RouteConfig([
        { path: '/', component: Home, as: 'Home' },
        { path: '/child/...', component: ChildItem, as: 'ChildItem' }
])
export class AppComponent {}

bootstrap(AppComponent, [ROUTER_PROVIDERS, provide(LocationStrategy, { useClass: HashLocationStrategy })])

Index.html

代码语言:javascript
复制
<html>
  <head>
    <title>Child Routing</title>
    <link rel="stylesheet" href="../node_modules/bootstrap/dist/css/bootstrap.min.css">
    <link rel="stylesheet" href="styles.css">
    <script src="../node_modules/angular2/bundles/angular2-polyfills.js"></script>
    <script src="../node_modules/systemjs/dist/system.src.js"></script>
    <script src="../node_modules/angular2/bundles/angular2.dev.js"></script>
    <script src="../node_modules/angular2/bundles/router.dev.js"></script>
    <script src="../node_modules/rxjs/bundles/rx.js"></script>
    <script>
      System.config({
        packages: {'app': {defaultExtension: 'js'}},
        baseURL: '/src'
      });
      System.import('app/app');
    </script>
  </head>
  <body>
    <my-app>Loading...</my-app>
  </body>
</html>

packages.json

代码语言:javascript
复制
{
  "name": "angular2-forms",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "tsc": "tsc -p src -w",
    "start": "live-server --open=src"
  },
  "keywords": [],
  "author": "John Tindell",
  "license": "ISC",
  "dependencies": {
    "angular2": "2.0.0-beta.0",
    "es6-module-loader": "0.17.8",
    "systemjs": "0.19.8",
    "es6-shim":"0.33.3",
    "rxjs": "5.0.0-beta.0"
  },
  "devDependencies": {
    "live-server": "^0.9.0",
    "typescript": "^1.7.3"
  }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-12-16 23:35:52

这可能对其他用户有用,所以我把它写成一个用户,评论可能太短了。

在您的RouteConfig中,您将ChildItem定义为父路由。/...部分使其成为父路由,这意味着它有子路由。

代码语言:javascript
复制
@RouteConfig([
        // This route is a parent route
        { path: '/child/...', component: ChildItem, as: 'ChildItem' }
])

因此,您不能简单地路由到['ChildItem']而不指定子路由,也不能不在路由中添加useAsDefault: true

所以你有两个选择:

  • 选项1:在您的一个子路由中添加useAsDefault: true
代码语言:javascript
复制
@RouteConfig([
        { path: '/1', component: SubItem1, as: 'SubItem1', useAsDefault: true},
        { path: '/2/', component: SubItem2, as: 'SubItem2' },
        { path: '/3/', component: SubItem3, as: 'SubItem3' }
])
export class ChildItem{}

使用此选项,每次导航到ChildItem时,它都会立即将您重定向到SubItem1Note as在阿尔法之前就被否决了,坚持name__。

  • 选项2:在链接中指定一个子元素(您可以通过两种方式实现这一点)
代码语言:javascript
复制
// First way
<a [routerLink]="['/ChildItem', 'SubItem1']">Click Me</a>

// Second way
<a [routerLink]="['/ChildItem/SubItem1']">Click Me</a>

这两种方法都是相似的,但第一种方法将允许您将参数传递到每条路由,例如:

代码语言:javascript
复制
// ChildItem gets "id"
// SubItem1 gets "itemName"
<a [routerLink]="['/ChildItem', {id: 'someId'}, 'SubItem1', {itemName: 'someName'}]">Click Me</a>

// Only SubItem1 gets "id"
<a [routerLink]="['/ChildItem/SubItem1', {id: 'someId'}]">Click Me</a>

我希望这是有益的和明确的。

票数 53
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34317678

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档