2つのテンプレート用のユーザーコンポーネントがあります。ユーザーテーブルの最初のテンプレート、ユーザーページの2番目のテンプレート。 role
属性で使用するテンプレートを選択します。使用してのangular2コンポーネントのselectorタグを削除します
まず例:別のテンプレートで
<table>
<tr user *ngFor="let user of users" [user]="user" role="UserTableItem"></tr>
</table>
が、私はこのように私のコンポーネントを使用します。
<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>
ここでは2つの成分、user-card
とuser-list-item
が見えます。 user-card
は、div
ブロックを含み、user-list-item
は、td
ブロックを含む。私は内部の<user-list-item>
ブロックを持っているので、テーブルがクラッシュし、私のテーブルには、次のようになります。
<table>
<tr>
<user-list-item>
<td></td>
<td></td>
</user-list-item>
</tr>
</table>
どのように私は私の問題を解決し、このようなテーブルを得ることができますか?
<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ここでそれを使用しますか? '
を使用することができますスニペットから正確に何を達成しようとしているのかを取得します。あなたはどのコンポーネントがどのコンポーネントのテンプレートであるかを知ることができるように、完全なコンポーネントコードを投稿してください。 「」などがある場合。 –
私の質問が更新されました – rel1x