首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用于类绑定的angular自定义指令

用于类绑定的angular自定义指令
EN

Stack Overflow用户
提问于 2021-07-23 23:15:20
回答 1查看 24关注 0票数 0

我的指令

代码语言:javascript
运行
复制
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
    }
  }
}

将指令用作:

代码语言:javascript
运行
复制
<course-card (courseSelected)="onCourseSelected($event)"
             [course]="course"
             [highlight]="highlight">

where highlight is BOOLEAN

类在DOM中被正确地应用为:class="bordered highlighted"

高亮显示的类有效果,但加边框的类没有效果

样式类定义为:

代码语言:javascript
运行
复制
.highlighted{
    box-shadow: 2px 2px 2px red;
}

.bordered {
    border-top: 5px solid lightgreen;
}

我不知道为什么会这样

EN

回答 1

Stack Overflow用户

发布于 2021-07-23 23:45:58

默认情况下,Angular组件对所有组件都有display:inline。由于样式对屏幕不可见,因此将课程组件显示类型更改为block

course.component.css

代码语言:javascript
运行
复制
:host { display: block; }

Working Example

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68501426

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档