gpt4 book ai didi

Angular 2 : routeLink does not create href attribute

转载 作者:太空狗 更新时间:2023-10-29 17:20:58 25 4
gpt4 key购买 nike

我有三个非常基本的组件:AppComponent , AdminComponentLoginComponent .两者 AppComponentLoginComponent显示指向 AdminComponent 的链接. AppComponent包含 router-outlet以及所有的路由配置。

现在出于某种原因 Angular 呈现 <a [routerLink]="['Admin']">Admin</a><a href="/admin">Admin</a>AppComponent正如预期的那样。但是,LoginComponent 中的完全相同的链接呈现给 <a>Admin</a> .我做错了什么?

尝试过 Angular 版本:2.0.0-beta.8 和 2.0.0-beta.9。

app.component.ts

import {Component} from 'angular2/core';
import {RouteConfig, ROUTER_DIRECTIVES} from 'angular2/router';

import {AdminComponent} from './admin.component';
import {LoginComponent} from './login.component';

@Component({
selector: 'ww-app',
template: `
<a [routerLink]="['Admin']">Admin</a> // This link works as expected

<router-outlet></router-outlet>
`,
directives: [ROUTER_DIRECTIVES]
})
@RouteConfig([
{ path: '/login', component: LoginComponent, name: 'Login', useAsDefault: true },
{ path: '/admin', component: AdminComponent, name: 'Admin' }
])
export class AppComponent {
}

login.component.ts

import {Component} from 'angular2/core';
import {RouterLink} from 'angular2/router';

@Component({
selector: 'ww-login',
directives: [RouterLink],
template: `
<div>
<a [routerLink]="['Admin']">Admin</a> // Renders <a>Admin</a>
<div>login box </div>
</div>
`
})
export class LoginComponent {
}

呈现的 HTML 输出

<ww-app>
<a href="/admin">Admin</a> <!-- link as expected (AppComponent)-->
<router-outlet></router-outlet>
<ww-login _ngcontent-nky-2="">
<div>
<a>Admin</a> <!-- href is missing here (LoginComponent)-->
<div>login box </div>
</div>
</ww-login>
</ww-app>

更新

好吧,我刚刚在 so Issue with routerLink directive 上偶然发现了一个类似的问题.看起来 angular2-polyfill.js 是个坏 child 。参见 Thierry's modified plunkr我从 index.html 中删除了 polyfill。

跟进问题:

angular2-polyfill声明自己为

Angular2 polyfill for Angular1

这样问可能很愚蠢,但我真的需要它吗?显然它为我解决了一个问题,但它给我一种不好的感觉,因为这不是 Angular 1。额外的弃用警告也无济于事......

最佳答案

我认为您的问题是您将指令设置为 [RouterLink]而不是 [ROUTER_DIRECTIVES] .

如果您看到代码,RouterLink 指令用于不同于 <a> 的其他标签.与 <a> 一起使用的路由器链接指令标签是 RouterLinkWithHref。

看看https://github.com/angular/angular/blob/master/modules/%40angular/router/src/directives/router_link.ts中的代码

@Directive({selector: ':not(a)[routerLink]'})
export class RouterLink { ... }

@Directive({selector: 'a[routerLink]'})
export class RouterLinkWithHref implements OnChanges, OnDestroy { ... }

关于 Angular 2 : routeLink does not create href attribute,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36061327/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com