Angular2 отримує ідентифікатор клікнутого елемента


85

У мене така подія клацання

 <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?

ОНОВЛЕННЯ: Планкери - це все добре, але в моєму випадку я маю локально:

event.srcElement.attributes.id- невизначений event.currentTarget.id- має значення

Я використовую chrome останньої версії 49.0.2623.87 m

Це може бути Material Design Liteріч? тому що я цим користуюся.

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


з чим ти хочеш робити id?
Пардіп Джейн

У мене є дві кнопки, що запускають ту саму функцію клацання. Тож мені потрібно з’ясувати, кого з них натиснули
sreginogemoh

просто передайте статичний / динамічний idразом з пераметрами.
Пардіп Джейн

чому так важко отримати id?
sreginogemoh

1
щойно виявив, що вevent.currentTarget.id
sreginogemoh

Відповіді:


139

Якщо ви хочете отримати доступ до 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;
  }
}

Дивіться цей додатковий файл: https://plnkr.co/edit/QGdou4?p=preview .

Дивіться це питання:


1
event.srcElement.attributes.idє невизначеним, не знаю чому ... але я знайшов idinevent.currentTarget.id
sreginogemoh

Справді? Ви бачили мою планку? Це те, що я використовую, і це не визначено ... У моєму випадку (Chrome), currentTargetне визначено :-( Яким браузером ви користуєтесь?
Тьєррі Темплієр

Насправді це або srcElement, або цільовий браузер. Переглянути це запитання: stackoverflow.com/questions/5301643/…
Тьєррі Темплієр

4
Хром:angular2.dev.js:23597 TypeError: Cannot read property 'nodeValue' of undefined
sreginogemoh

4
Я закінчую цим користуватисяvar target = event.srcElement.attributes.id || event.currentTarget.id;
sreginogemoh

36

Для користувачів TypeScript:

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

5
На мій погляд, це має бути прийнятою відповіддю, проте це може бути const elementId: string = (event.target as Element).id;
Харіш

1
що для мене повертається порожнім. Не нульовий чи невизначений, але порожній
Даррен-стріт,

Дякую. Я був настільки розгублений, чому я не міг перевірити властивість target, або srcTarget, безпосередньо, коли бачив їх усі в консолі. У ролях Елемента, duh.
Джеремі Л

Це, безумовно, має бути головною відповіддю.
Ніхто Десь

19

Нарешті знайшов найпростіший спосіб:

<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); 
}

Це може бути хитро: якщо ваша кнопка має якийсь вміст HTML, наприклад, <button ...><i class="fa fa-check"></i></button>і ви насправді натискаєте на цей iелемент, який є компонентом FontAwasome, тоді event.target - це не елемент, buttonа iелемент.
Скорунка Франтішек

2
Щоб отримати buttonелемент, використовуйте event.target.closest('button').
Скорунка Франтішек

18

Ви можете просто передати статичне значення (або змінну від *ngForабо чого завгодно)

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

чи вважаєте ви, що краще уникати використання idв такому випадку?
sreginogemoh

1
Якщо єдиною метою є передавати його як параметр події, тоді я б не використовував ідентифікатор.
Günter Zöchbauer

1
Замість використання idпросто виберіть індекс з масиву або близько того. Часто дивує те, що ми так часто пропускаємо найпростіші рішення.
Юрій

9

Немає необхідності передавати всю подію (якщо вам не потрібні інші аспекти події, ніж ви заявили). Насправді це не рекомендується. Ви можете передати посилання на елемент лише з невеликими змінами.

import {Component} from 'angular2/core';

@Component({
  selector: 'my-app',
  template: `
    <button #btn1 (click)="toggle(btn1)" class="someclass" id="btn1">Button 1</button>
    <button #btn2 (click)="toggle(btn2)" class="someclass" id="btn2">Button 2</button>
  `
})
export class AppComponent {
  buttonValue: string;

  toggle(button) {
    this.buttonValue = button.id;
  }

}

Демонстрація StackBlitz

Технічно вам не потрібно знаходити кнопку, на яку клацнули, оскільки ви передали фактичний елемент.

Кутове наведення


Це має бути правильна відповідь, на яку посилається @ Greg's Link to Angular guide!
Chrizzldi

4

Коли у вас HTMLElementнемає id, nameабоclass для виклику,

потім використовувати

<input type="text" (click)="selectedInput($event)">

selectedInput(event: MouseEvent) {
   log(event.srcElement) // HTMInputLElement
}

2

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

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);
  }
}

демонстрація: http://plnkr.co/edit/5kJaj9D13srJxmod213r?p=preview


4
event.srcElement.attributes.idв моєму випадку не визначено, не знаю чому ... але я знайшов idinevent.currentTarget.id
sreginogemoh

просто замовлення в Об’єкті eventзвільненого, де ви можете побачитиid
Пардіп Джейн

1
@sreginogemoth ви також можете перевірити: event.target.idвін також може мати значення ідентифікатора
Артур,

2

Ви можете використовувати його інтерфейс, HTMLButtonElement який успадковується від батьків HTMLElement!

Таким чином ви зможете мати автозаповнення ...

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

toggle(event: MouseEvent) {
    const button = event.target as HTMLButtonElement;
    console.log(button.id);
    console.log(button.className);
 }

Щоб переглянути весь список HTMLElement з документації Консорціуму Всесвітньої павутини (W3C)

Демонстрація StackBlitz


0

Якщо ви хочете отримати доступ до idатрибута кнопки в кутовому 6, дотримуйтесь цього коду

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

ваше idзначення,

значення valueє myId.

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.