我的指令
import { Directive, HostBinding, Input } from '@angular/core';
@Directive({
selector: '[highlight]'
})
export class HighlightDirective {
@Input('highlight') isHighlighted = false;
constructor() {}
@HostBinding('class')
get function () {
return {
'highlighted': this.isHighlighted,
'bordered': this.isHighlighted
}
}
}
将指令用作:
<course-card (courseSelected)="onCourseSelected($event)"
[course]="course"
[highlight]="highlight">
where highlight is BOOLEAN
类在DOM中被正确地应用为:class="bordered highlighted"
。
高亮显示的类有效果,但加边框的类没有效果
样式类定义为:
.highlighted{
box-shadow: 2px 2px 2px red;
}
.bordered {
border-top: 5px solid lightgreen;
}
我不知道为什么会这样
发布于 2021-07-23 23:45:58
默认情况下,Angular组件对所有组件都有display:inline。由于样式对屏幕不可见,因此将课程组件显示类型更改为block
course.component.css
:host { display: block; }
https://stackoverflow.com/questions/68501426
复制相似问题