Подтвердить что ты не робот

Angular2 получить идентификатор элемента clicked

У меня есть событие click

 <button (click)="toggle($event)" class="someclass" id="btn1"></button>
 <button (click)="toggle($event)" class="someclass" id="btn2"></button>

Я улавливаю событие в параметре ввода функции и хочу узнать, что именно нажата кнопка.

toggle(event) {

}

но event не имеет свойства id.

altKey: false
bubbles: true
button: 0
buttons: 0
cancelBubble: false
cancelable: true
clientX: 1198
clientY: 29
ctrlKey: false
currentTarget: button#hdrbtn_notificaton.mdl-button.mdl-js-button.mdl-js-ripple-effect.mdl-button--icon
defaultPrevented: false
detail: 1
eventPhase: 3
fromElement: null
isTrusted: true
isTrusted: true
layerX: -566
layerY: 5
metaKey: false
movementX: 0
movementY: 0
offsetX: 22
offsetY: 13
pageX: 1198
pageY: 29
path: Array[13]
relatedTarget: null
returnValue: true
screenX: 1797
screenY: 148
shiftKey: false
sourceCapabilities: InputDeviceCapabilities
srcElement: span.mdl-button__ripple-container
target: span.mdl-button__ripple-container
timeStamp: 1458032708743
toElement: span.mdl-button__ripple-container
type: "click"
view: Window
webkitMovementX: 0
webkitMovementY: 0
which: 1
x: 1198
y: 29

Как найти id?

UPDATE: Plunkers все хороши, но в моем случае я локально:

event.srcElement.attributes.id - undefined event.currentTarget.id - имеет значение

Я использую chrome последней версии 49.0.2623.87 м

Может ли это быть Material Design Lite вещь? потому что я использую его.

введите описание изображения здесь

4b9b3361

Ответ 1

Если вы хотите получить доступ к атрибуту id кнопки, вы можете использовать свойство srcElement события:

import {Component} from 'angular2/core';

@Component({
  selector: 'my-app',
  template: `
    <button (click)="onClick($event)" id="test">Click</button>
  `
})
export class AppComponent {
  onClick(event) {
    var target = event.target || event.srcElement || event.currentTarget;
    var idAttr = target.attributes.id;
    var value = idAttr.nodeValue;
  }
}

Смотрите этот plunkr: https://plnkr.co/edit/QGdou4?p=preview.

Смотрите этот вопрос:

Ответ 2

Вы можете просто передать статическое значение (или переменную из *ngFor или что-то еще)

<button (click)="toggle(1)" class="someclass">
<button (click)="toggle(2)" class="someclass">

Ответ 3

Наконец нашел самый простой способ:

<button (click)="toggle($event)" class="someclass" id="btn1"></button>
<button (click)="toggle($event)" class="someclass" id="btn2"></button>

toggle(event) {
   console.log(event.target.id); 
}

Ответ 4

Для пользователей TypeScript:

    toggle(event: Event): void {
        let elementId: string = (event.target as Element).id;
        // do something with the id... 
    }

Ответ 5

сделать это просто: (как сказано в комментарии здесь, пример с двумя методами)

import {Component} from 'angular2/core';

@Component({
    selector: 'my-app', 
    template: `
      <button (click)="checkEvent($event,'a')" id="abc" class="def">Display Toastr</button>
      <button (click)="checkEvent($event,'b')" id="abc1" class="def1">Display Toastr1</button>
    `
})
export class AppComponent {
  checkEvent(event, id){
    console.log(event, id, event.srcElement.attributes.id);
  }
}

demo: http://plnkr.co/edit/5kJaj9D13srJxmod213r?p=preview