gpt4 book ai didi

angularjs - 删除 angular 2 组件选择器标签

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

我有一个用于 2 个模板的用户组件。用户表的第一个模板,用户页面的第二个模板。我通过 role 选择要使用的模板属性。

第一个使用示例:

<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>

正如我们所见,这里有两个组件 user-carduser-list-item . user-card包含 div block ,user-list-item包含 td block 。表崩溃了,因为我有一个 <user-list-item>挡在里面,我的 table 看起来像:

<table>
<tr>
<user-list-item>
<td></td>
<td></td>
</user-list-item>
</tr>
</table>

我怎样才能解决我的问题并获得这样的表格?

<table>
<tr>
<td></td>
<td></td>
</tr>
</table>

更新:

我的 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>
// ...

最佳答案

我觉得你的问题有点令人困惑,但我猜你想要的是一个属性选择器

@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>

关于angularjs - 删除 angular 2 组件选择器标签,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38994620/

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