删除angular2组件的选择器标签 [英] Remove the angular2 component's selector tag
问题描述
我有2个模板的用户组件.用户表的第一个模板,用户页面的第二个模板.我通过role
属性选择要使用的模板.
I have a user component for 2 templates. First template for users table, second one for a user page. I select which template to use by role
attribute.
第一个使用示例:
<table>
<tr user *ngFor="let user of users" [user]="user" role="UserTableItem"></tr>
</table>
在另一个模板中,我使用这样的组件:
In another one template I use my component like this:
<div user [user]="user" role="UserCard"></div>
所以,我的user
组件模板:
// user.template.html
<user-card [user]="user" *ngIf="role === 'UserCard'"></user-card>
<user-list-item [user]="user" *ngIf="role === 'UserListItem'"></user-list-item>
我们可以看到,这里有两个组件user-card
和user-list-item
. user-card
包含div
块,user-list-item
包含td
块.由于我里面有一个<user-list-item>
块并且表看起来像这样,所以表崩溃了:
As we can see, here two components user-card
and user-list-item
. user-card
contains div
blocks, user-list-item
contains td
blocks. And table crashed because I have a <user-list-item>
block inside and my table looks like:
<table>
<tr>
<user-list-item>
<td></td>
<td></td>
</user-list-item>
</tr>
</table>
如何解决我的问题并得到这样的表?
How can I solve my problem and get table like this?
<table>
<tr>
<td></td>
<td></td>
</tr>
</table>
UPD:
我的user
组件:
// user.component.ts
import { Component, Input, Inject, Attribute } from '@angular/core';
import { UserCard } from './userCard.component';
import { UserListItem } from './userListItem.component';
@Component({
selector: '[user]',
templateUrl: './user.template.html',
directives: [UserCard, UserListItem]
})
export class User {
@Input() user:any = null;
role:string;
constructor(
@Attribute('role') role) {
this.role = role;
}
}
userListItem.template.html
:
<td>
{{user.id}}
</td>
<td>
<img src="{{user.avatarUrl160}}" alt="User profile picture" width="160">
</td>
// ...
userCard.template.html
:
<div class="card card-block" *ngIf="user">
<h4 class="card-title">
User #{{user.id}}
<span class="tag tag-success" *ngIf="!user.isBanned">Active</span>
<span class="tag tag-danger" *ngIf="user.isBanned">Banned</span>
<span class="tag tag-danger" *ngIf="user.isDeleted">Deleted</span>
</h4>
<p>
<img width="340" src="{{user.avatarUrl160}}">
// ...
</div>
<div class="card card-block" *ngIf="user">
<span class="text-muted">Company: </span> {{user.company.name}}<br>
<span class="text-muted">Company logo: </span>
// ...
推荐答案
我发现您的问题有些令人困惑,但我想您想要的是属性选择器
I find your question a bit confusing but I guess what you want is an attribute selector
@Component({
selector: '[user-list-item]',
...
})
export class UserListItem { ... }
而不是
<user-card [user]="user" *ngIf="role === 'UserCard'"></user-card>
<user-list-item [user]="user" *ngIf="role === 'UserListItem'"></user-list-item>
使用
<td user-card [user]="user" *ngIf="role === 'UserCard'"></td>
<td user-list-item [user]="user" *ngIf="role === 'UserListItem'"></td>
这篇关于删除angular2组件的选择器标签的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!