[英]How can I access aria-expanded value of a button
如何從單擊偵聽器訪問按鈕屬性? 我想訪問 aria-expanded 來設置一些值; 這是我得到的。
x.html
<button class="btn btn-secondary" (click)="customSearch($event.target)" type="button" data-toggle="collapse" data-target="#collapseForm" aria-expanded="false" aria-controls="collapseForm">Search</button>
x.ts
customSearch(e){
console.log("some event--->",e);
}
結果
由於您已經將 dom 對象作為參數傳遞,您可以使用 getAttribute 方法直接獲取其屬性
customSearch(buttonDOM) { console.log("some event--->", buttonDOM.getAttribute('aria-expanded')); }
我建議您創建一個修改按鈕的指令,這是一個示例
import { Directive, ElementRef, Renderer, HostListener } from '@angular/core';
@Directive({
selector: '[aextended]'
})
export class AextendedDirective {
constructor(private el: ElementRef, private renderer: Renderer) {
}
@HostListener('click') onClick() {
this.el.nativeElement.setAttribute('aria-expanded','true');
}
}
然后在你的模板中
<button aextended class="btn btn-secondary" (click)="customSearch($event.target)" type="button" data-toggle="collapse" data-target="#collapseForm" aria-expanded="true" aria-controls="collapseForm">Search</button>
這是一個工作案例的堆棧閃電戰
如果你真的想從控制器設置它,你可以這樣做
customSearch(el){
el.setAttribute('aria-expanded','true')
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.