Angular2 รับรหัสองค์ประกอบที่คลิก


88

ฉันมีเหตุการณ์คลิกดังกล่าว

 <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- ไม่ได้กำหนด event.currentTarget.id- มีค่า

ฉันใช้ Chrome เวอร์ชันล่าสุด 49.0.2623.87 ม

มันอาจจะเป็นMaterial Design Liteเรื่อง? เพราะฉันกำลังใช้มัน

ใส่คำอธิบายภาพที่นี่


คุณต้องการทำidอะไร?
Pardeep Jain

ฉันมีสองปุ่มที่ใช้ฟังก์ชันคลิกเดียวกัน ดังนั้นฉันต้องหาว่าอัน
ไหน

เพียงแค่ส่งแบบคงที่ / ไดนามิกidพร้อมกับเครื่องวัดค่า
Pardeep Jain

ทำไมจึงยากที่จะได้รับid?
sreginogemoh

1
เพิ่งพบว่าในevent.currentTarget.id
sreginogemoh

คำตอบ:


144

หากคุณต้องการเข้าถึง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

ดูคำถามนี้:


1
event.srcElement.attributes.idไม่ได้กำหนดไม่ทราบว่าทำไม ... แต่ฉันพบidในevent.currentTarget.id
sreginogemoh

จริงๆ? คุณเห็น plunkr ของฉันหรือไม่? มันคือสิ่งที่ฉันใช้และไม่ได้กำหนดไว้ ... ในกรณีของฉัน (Chrome) currentTargetไม่ได้กำหนด :-( คุณใช้เบราว์เซอร์ใด
Thierry Templier

ในความเป็นจริงมันเป็นทั้ง srcElement หรือกำหนดเป้าหมายตามเบราว์เซอร์ ดูคำถามนี้: stackoverflow.com/questions/5301643/…
Thierry Templier

4
Chrome:angular2.dev.js:23597 TypeError: Cannot read property 'nodeValue' of undefined
sreginogemoh

4
ฉันสิ้นสุดการใช้สิ่งนี้var target = event.srcElement.attributes.id || event.currentTarget.id;
sreginogemoh

37

สำหรับผู้ใช้ 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;
Harish

1
ที่คืนค่าว่างให้ฉัน ไม่ว่างหรือไม่ได้กำหนด แต่ว่างเปล่า
Darren Street

ขอบคุณ. ฉันสับสนมากว่าทำไมฉันไม่สามารถตรวจสอบคุณสมบัติของเป้าหมายหรือ srcTarget ได้โดยตรงในเมื่อฉันเห็นทั้งหมดในคอนโซล ร่ายเป็นธาตุ duh
Jeremy L

นี่น่าจะเป็นคำตอบอันดับต้น ๆ แน่นอน
NobodySomewhere

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องค์ประกอบ
Skorunka František

2
ที่จะได้รับการใช้องค์ประกอบbutton event.target.closest('button')
Skorunka František

19

คุณสามารถส่งผ่านค่าคงที่ (หรือตัวแปรจาก*ngForหรืออะไรก็ได้)

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

คุณคิดว่าการหลีกเลี่ยงการใช้idในกรณีเช่นนี้จะดีกว่าไหม
sreginogemoh

1
หากจุดประสงค์เดียวคือการส่งผ่านเป็นพารามิเตอร์เหตุการณ์ฉันจะไม่ใช้ id
GünterZöchbauer

1
แทนที่จะใช้idเพียงแค่เลือกดัชนีจากอาร์เรย์หรือมากกว่านั้น มักจะน่าแปลกใจที่เรามองข้ามวิธีแก้ปัญหาแบบตรงไปตรงมาบ่อย
Yuri

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 ไปยังคำแนะนำเชิงมุม!
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ไม่ได้กำหนดไว้ในกรณีของฉันไม่รู้ว่าทำไม ... แต่ฉันพบidในevent.currentTarget.id
sreginogemoh

เพียงแค่ชำระเงินในวัตถุeventยิงที่คุณสามารถดูได้id
Pardeep Jain

1
@sreginogemoth คุณสามารถตรวจสอบได้เช่นกัน: event.target.idมันยังสามารถมีค่า ID ได้
Arthur

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 ทั้งหมดจากเอกสาร World Wide Web Consortium (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.

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.