#javascript #angular #typescript #checkbox #angular-material
#javascript #angular #typescript #установите флажок #angular-материал
Вопрос:
Я перепробовал все, но не могу получить желаемый ответ. Как я могу сделать всю строку интерактивной, и когда я нажимаю, флажок должен быть установлен, а строка должна быть активной, есть идеи
Вот мой html-файл
<section class="others" >
<div class="sub-header">Others</div>
<p class="text-center" *ngIf="otherTests.length === 0">No Tests Available</p>
<app-custom-accordion [closeOthers]="true">
<ngb-panel [disabled]="true" *ngFor="let testPanel of otherTests let i = index;" id="{{testPanel.Id}}" [title]="testPanel.Name">
<ng-template ngbPanelTitle>
<div class="action-items">
<span class="material-icons fav" [class.favorited]="testPanel.Favorite" (click)="onFavoriteClick(testPanel)"></span>
<span class="icon-set" [ngClass]="{'same-day-2x': isSameDay(testPanel.Code), 'next-day-2x': isNextDay(testPanel.Code)}"></span>
<label class="custom-control custom-checkbox">
<input
type="checkbox"
class="custom-control-input"
[name]="testPanel.Id '-' testPanel.Moniker"
[ngModel]="panelIds.indexOf(testPanel.Id) > -1"
(ngModelChange)="onPanelCheckboxUpdate($event, testPanel)"
[id]="testPanel.Id '-' testPanel.Moniker">
<span class="custom-control-indicator"></span>
</label>
</div>
</ng-template>
</ngb-panel>
</app-custom-accordion>
</section>
это моя панель
Вот мой Ts-файл для изменения флажка
public panelIds: Array<number>;
onPanelCheckboxUpdate($event: boolean, panel: TestOrderPanel) {
this.checked = $event
let testPanelIds = panel.Tests.map(test => test.Id);
// Wipe any duplicates
this.panelIds = this.panelIds.filter(
panelId => panel.Id !== panelId amp;amp; testPanelIds.indexOf(panelId) === -1
);
this.selectedPanels = this.selectedPanels.filter(
selectedPanel =>
panel.Id !== selectedPanel.Id amp;amp;
testPanelIds.indexOf(selectedPanel.Id) === -1
);
if ($event) {
this.panelIds.push(panel.Id);
this.selectedPanels.push(panel);
}
this.updateSession();
}
Это компонент моего приложения, созданный на основе пользовательского аккордеона
<div class="card">
<ng-template ngFor let-panel [ngForOf]="panels">
<div role="tab" id="{{panel.id}}-header" [class]="'card-header '
(panel.type ? 'card-' panel.type: type ? 'card-' type : '')"
[class.active]="isOpen(panel.id)">
<a href (click)="!!toggle(panel.id)" [attr.tabindex]=" .
(panel.disabled
? '-1' : null)" [attr.aria-expanded]="isOpen(panel.id)"
[attr.aria-controls]="(isOpen(panel.id) ? panel.id : null)"
[attr.aria-disabled]="panel.disabled">{{panel.title}}</a>
<ng-template [ngTemplateOutlet]="panel.titleTpl?.templateRef"></ng-
template>
<!-- expansion arrows -->
<div *ngIf="arrowExpand" (click)="toggle(panel.id)" [attr.aria-
expanded]="isOpen(panel.id)">
<span class="material-icons expand"></span>
</div>
</div>
<div id="{{panel.id}}" role="tabpanel" [attr.aria-labelledby]="panel.id '-header'" class="card-block" *ngIf="isOpen(panel.id) amp;amp; panel.contentTpl">
<ng-template [ngTemplateOutlet]="panel.contentTpl?.templateRef"></ng-template>
</div>
</ng-template>
</div>
Как изменить цвет всей строки при нажатии на флажок
например, когда установлен флажок, вся строка должна быть темной или что-то еще, а когда флажок снят, должен быть предыдущий цвет, то есть белый
кто-нибудь может помочь? Спасибо
Комментарии:
1. сделайте одну вещь, добавьте одно свойство на панель тестирования, подобное выбранному, и при нажатии на строку / div установите для него значение true, а при нажатии на другие строки сделайте все выбранные значения false и нажатое значение true
2. не могли бы вы, пожалуйста, немного объяснить, спасибо @JayantPatil
3. Пример StackBlitz мог бы помочь нам решить вашу проблему.
4. привяжите свой текст и флажок в
<label></label>
‘s5. сработает ли это? 😀 @TusharWalzade