javascript - 在 Angular 中单击指令属性元素外部时将样式应用于元素

标签 javascript html css angular svg

我有 svg 元素,当用户单击或悬停它们时,它们会突出显示相应的路径。

我正在使用指令来检测 onEnter onLeaveClick 事件。

当我悬停(我突出显示)然后当我离开元素(我播放下来)时它工作正常

然后当我单击时,路径也会突出显示(

实际上,当我单击其他地方时,突出显示会保留。

我不能这样做的是,当我单击屏幕的其余部分时,我希望突出显示消失。

这是我的指令逻辑

export class HighlightDirective {
  constructor(private renderer:Renderer2 , private el: ElementRef) {}
  clicked=false
  @HostListener('mouseenter') onMouseEnter() {
    this.changeOpacity(1);
  }

  @HostListener('mouseleave') onMouseLeave() {
    if (!this.clicked) {
      this.changeOpacity(0);
    }
  }
  @HostListener('click') click() {
    this.changeOpacity(1);
    this.clicked = true;
  }
  changeOpacity(opacity: number) {
    this.renderer.setStyle(this.el.nativeElement.nextSibling, 'opacity', opacity);
  }

}

这是带有Highlight属性标签的SVG的一部分

 <g id="b1" transform="translate(-885 -562)">
    <g id="b1select">
      <ellipse id="Ellipse_1" data-name="Ellipse 1" cx="5.3" cy="5.3" rx="5.3" ry="5.3" transform="translate(1309.17 932.12)" fill="none" stroke="#b18802" stroke-width="1"/>
      <text id="B1-2" data-name="B1" transform="translate(1310.67 939.62)" fill="#b18802" font-size="6" font-family="ArialMT, Arial"><tspan x="0" y="0">B1</tspan></text>
    </g>
    <rect appHighlight (click)="openDialog($event)" id="container" width="12" height="11" transform="translate(1308.67 931.62)" fill="rgba(255,255,255,0)"/>
    <path id="b1-3" data-name="b1" d="M1093.763,1595.658v-82.417s5-14.987-18.452-16.644-40.9,2.386-54.093-11.537-132.873-159.193-132.873-159.193-6.456-10.249-24.986-14.661-9.858-17.907-4.728-25.235,39.039-47.23,39.039-47.23" transform="translate(208.67 -656.38)" fill="none" stroke="#efcf2f" stroke-linecap="round" stroke-width="2"/>
  </g>

这是 stackBlitz 的示例

最佳答案

document.removeEventListener('mousedown', this.scroll);

我使用的是,每当 mousedown 事件触发时,removeListner 就会删除滚动事件。我们在使用 addEventListner() 之前添加了它。 this.scroll 是您定义的事件来执行您想做的事情。

关于javascript - 在 Angular 中单击指令属性元素外部时将样式应用于元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58545289/

相关文章:

Javascript 幻灯片中心?

html - 如何将表格中的图像对齐到一行或其他内容的右侧?

html - 固定元素相对于容器的定位

javascript - 如何在整个 div 上应用链接?

javascript - 如何在 firebase 上托管 Nodejs/Express 后端?

JavaScript 自定义事件监听器

javascript - 用于调整两个 div 大小的垂直拖动条

javascript - 将事件绑定(bind)到列表元素

javascript - ExtJS 4.1 或通用 Javascript HTTP_Authorization 函数

javascript - 在 GraphQL 中返回关系数据时遇到问题