javascript - 单击时自动聚焦 ng-multiselect-dropdown 的 Filterfield

标签 javascript html angular typescript ng-multiselect-dropdown

我在我的 Angular 项目中使用了 ng-multiselect-dropdown 包 ( https://www.npmjs.com/package/ng-multiselect-dropdown )。一切正常,但我想在打开多选下拉菜单时自动聚焦过滤器输入字段。

这是我的 html 代码:

<div class="input-group" style="display: flex">
                <span class="input-group-text"><i class="fas fa-building"></i></span>
                <ng-multiselect-dropdown style="flex: 1"
                                         [placeholder]="'Unternehmen'"
                                         [data]="this.companies"
                                         [formControl]="filterCompany"
                                         [settings]="dropdownSettingsCompanies"
                                         (onFilterChange)="updateCompanyList($event)"
                                         (onSelect)="onItemSelect($event)">
                </ng-multiselect-dropdown>
</div>

这里是我的多选设置:

dropdownSettingsCompanies: any = {
        singleSelection: false,
        idField: 'id',
        textField: 'name',
        showSelectedItemsAtTop: true,
        clearSearchFilter: true,
        allowSearchFilter: this.ShowFilter,
        enableCheckAll: false,
        allowRemoteDataSearch: true,
        searchPlaceholderText: 'Bitte geben Sie einen Suchbegriff ein',
    };

最佳答案

项目内部没有这个功能,需要自己写。我正在使用指令并使用 querySelector 获取输入元素并聚焦输入!

import { Directive, ElementRef, HostListener } from '@angular/core';

@Directive({
  selector: '[appFocusOnClick]',
})
export class FocusOnClickDirective {
  constructor(private elementRef: ElementRef) {}

  @HostListener('click', ['$event.target'])
  onClick(btn) {
    console.log('button', btn, 'number of clicks:');
    const input = this.elementRef.nativeElement.querySelector(
      '.filter-textbox > input'
    );
    if (input) {
      input.focus();
    }
  }
}

stackblitz

关于javascript - 单击时自动聚焦 ng-multiselect-dropdown 的 Filterfield,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/73332490/

相关文章:

javascript - Javascript 上的数字根练习

javascript - 如何选择父节点的第一个子节点?

angular - 如何为 Angular2 测试配置 webpack?

javascript - 如何为可调整大小的 jQuery UI 元素启动调整大小功能(触发句柄拖动)

javascript - 需要正则表达式来评估连字符分隔值,其中第一个限制应始终小于第二个限制

html - 使整个 div 可点击但保持当前样式的最佳方法是什么?

ios - Nativescript Angular 模拟器不使用 tns run ios 刷新

css - Webpack 加载 primeng.min.css 时出错

javascript - 如何检查用户在浏览器中输入地址URL并点击书签?

html - 悬停更改我所有的 li 标签