如何在angular2中向组件的父dom元素添加属性?

时间:2016-10-24 13:55:03

标签: html angular typescript dom-manipulation

我有以下内容:

...
<div class="container">
  <div class="fancy">
    <fancybutton></fancybutton>
  </div>
  <button (click)="addAttribute()">Remove</button>
  <button (click)="remAttribute()">Add</button>
</div>

... 我的问题是,我怎样才能让用户点击&#34; addAttribute()&#34;它添加了&#34; testattribute&#34;到这个组件的父dom元素,如下所示:

  <div class="fancy" testattribute="a">
    <fancybutton></fancybutton>
  </div>

这是我的花哨按钮组件,下面是我在home.component.html中集成了花式按钮的父模板:

@Component({
  selector: 'fancy-button',
  template: `<button>clickme</button>`
})
export class FancyButton {}

@Component({
  selector: 'home',  // <home></home>
  providers: [
    Title
  ],
  styleUrls: [ './home.component.css' ],
  templateUrl: './home.component.html'
})

2 个答案:

答案 0 :(得分:1)

<div class="container">
  <div class="fancy" [attr.testattribute]="isAttr">
    <fancybutton></fancybutton>
  </div>
  <button (click)="isAttr = true">Remove</button>
  <button (click)="isAttr = false">Add</button>
</div>

答案 1 :(得分:0)

我有一个可能的解决方案(在撰写本文时未经测试):

将参数的名称和值添加到addAttribute()调用中,如下所示:

addAttribute("testattribute", "a");

您还需要将this.parentElement添加到通话开头:

this.parentElement.addAttribute("testattribute", a");

如果此解决方案适合您,请告诉我。