ngx-mat-select-search

ngx-mat-select-search

为 Angular Material Select 增添搜索功能

NgxMatSelectSearch 为 Angular Material Select 组件增添搜索功能,支持单多选模式,易于集成。它优化了大型选项列表的使用体验,是 Angular Material 官方实现前的实用解决方案。该开源库显著提升了选项筛选和定位效率,为开发者提供了灵活且高效的选择组件增强工具。

NgxMatSelectSearchAngularMaterial组件搜索过滤Github开源项目

NgxMatSelectSearch

https://github.com/bithost-gmbh/ngx-mat-select-search

npm 版本 npm 总下载量 npm 月下载量 CircleCI 捐赠

它有什么作用?

这是一个Angular组件,为Angular Material库的MatSelect选项提供一个输入字段用于搜索/过滤。

<img src="https://yellow-cdn.veclightyear.com/0a4dffa0/ffb36202-5719-49fc-a20b-67e63a138f27.png" alt="示例" width="293"/>

试一试

在以下链接可以看到实际效果:

重要提示:本项目是https://github.com/angular/material2/issues/5697的临时实现。 最终目标是在官方Angular Material仓库中实现,将创建一个新的PR。

贡献

欢迎贡献,请开启一个issue,最好提交一个pull request。

支持开发

我们致力于通过不断改进NgxMatSelectSearch并快速响应错误报告来提供最佳服务。我们完全免费提供这些服务。 如果您觉得这个库对您有用,为您和您的业务节省了宝贵的时间,请考虑捐赠以支持其维护和进一步开发。

PayPal

财务支持者

非常感谢我们的财务支持者!

<!-- readme: pschulzk,sponsors -start --> <table> <tr> <td align="center"> <a href="https://github.com/pschulzk"> <img src="https://avatars.githubusercontent.com/u/7001048?v=4" width="100;" alt="pschulzk"/> <br /> <sub><b>Philip Viktor Schulz-Klingauf</b></sub> </a> </td></tr> </table> <!-- readme: pschulzk,sponsors -end -->

协作者

<!-- readme: collaborators -start --> <table> </table> <!-- readme: collaborators -end -->

贡献者

非常感谢我们所有的社区贡献者!

<!-- readme: contributors -start --> <table> <tr> <td align="center"> <a href="https://github.com/macjohnny"> <img src="https://avatars.githubusercontent.com/u/5589029?v=4" width="100;" alt="macjohnny"/> <br /> <sub><b>Esteban Gehring</b></sub> </a> </td> <td align="center"> <a href="https://github.com/maechler"> <img src="https://avatars.githubusercontent.com/u/4113819?v=4" width="100;" alt="maechler"/> <br /> <sub><b>Markus Mächler</b></sub> </a> </td> <td align="center"> <a href="https://github.com/angelaki"> <img src="https://avatars.githubusercontent.com/u/38611461?v=4" width="100;" alt="angelaki"/> <br /> <sub><b>Tristan</b></sub> </a> </td> <td align="center"> <a href="https://github.com/tonyholt"> <img src="https://avatars.githubusercontent.com/u/893926?v=4" width="100;" alt="tonyholt"/> <br /> <sub><b>Tony H</b></sub> </a> </td> <td align="center"> <a href="https://github.com/mstawick"> <img src="https://avatars.githubusercontent.com/u/1216844?v=4" width="100;" alt="mstawick"/> <br /> <sub><b>Michał Stawicki</b></sub> </a> </td> <td align="center"> <a href="https://github.com/alexandrupaul7"> <img src="https://avatars.githubusercontent.com/u/28051061?v=4" width="100;" alt="alexandrupaul7"/> <br /> <sub><b>Null</b></sub> </a> </td></tr> <tr> <td align="center"> <a href="https://github.com/blazewalker59"> <img src="https://avatars.githubusercontent.com/u/21110755?v=4" width="100;" alt="blazewalker59"/> <br /> <sub><b>Blaze Walker</b></sub> </a> </td> <td align="center"> <a href="https://github.com/achilehero"> <img src="https://avatars.githubusercontent.com/u/14956052?v=4" width="100;" alt="achilehero"/> <br /> <sub><b>Cristian Raducanu</b></sub> </a> </td> <td align="center"> <a href="https://github.com/damianmigo"> <img src="https://avatars.githubusercontent.com/u/1733403?v=4" width="100;" alt="damianmigo"/> <br /> <sub><b>Damian Miranda</b></sub> </a> </td> <td align="center"> <a href="https://github.com/Danevandy99"> <img src="https://avatars.githubusercontent.com/u/13788320?v=4" width="100;" alt="Danevandy99"/> <br /> <sub><b>Dane Vanderbilt</b></sub> </a> </td> <td align="center"> <a href="https://github.com/escheiermann"> <img src="https://avatars.githubusercontent.com/u/39056343?v=4" width="100;" alt="escheiermann"/> <br /> <sub><b>Edgar Scheiermann</b></sub> </a> </td> <td align="center"> <a href="https://github.com/arucar"> <img src="https://avatars.githubusercontent.com/u/37804893?v=4" width="100;" alt="arucar"/> <br /> <sub><b>Erendis</b></sub> </a> </td></tr> <tr> <td align="center"> <a href="https://github.com/gustavovitor"> <img src="https://avatars.githubusercontent.com/u/37344068?v=4" width="100;" alt="gustavovitor"/> <br /> <sub><b>Gustavo Miranda</b></sub> </a> </td> <td align="center"> <a href="https://github.com/meta72"> <img src="https://avatars.githubusercontent.com/u/3915589?v=4" width="100;" alt="meta72"/> <br /> <sub><b>Henno Lauinger</b></sub> </a> </td> <td align="center"> <a href="https://github.com/himanshu-singh1995"> <img src="https://avatars.githubusercontent.com/u/29891513?v=4" width="100;" alt="himanshu-singh1995"/> <br /> <sub><b>空</b></sub> </a> </td> <td align="center"> <a href="https://github.com/jfcere"> <img src="https://avatars.githubusercontent.com/u/6987084?v=4" width="100;" alt="jfcere"/> <br /> <sub><b>Jean-Francois Cere</b></sub> </a> </td> <td align="center"> <a href="https://github.com/josephdecock"> <img src="https://avatars.githubusercontent.com/u/1145533?v=4" width="100;" alt="josephdecock"/> <br /> <sub><b>Joe DeCock</b></sub> </a> </td> <td align="center"> <a href="https://github.com/JomalJohny"> <img src="https://avatars.githubusercontent.com/u/43292719?v=4" width="100;" alt="JomalJohny"/> <br /> <sub><b>Jomal Johny</b></sub> </a> </td></tr> <tr> <td align="center"> <a href="https://github.com/bulldog98"> <img src="https://avatars.githubusercontent.com/u/314259?v=4" width="100;" alt="bulldog98"/> <br /> <sub><b>Jonathan Kolberg</b></sub> </a> </td> <td align="center"> <a href="https://github.com/melroy89"> <img src="https://avatars.githubusercontent.com/u/628926?v=4" width="100;" alt="melroy89"/> <br /> <sub><b>Melroy Van Den Berg</b></sub> </a> </td> <td align="center"> <a href="https://github.com/AhsanAyaz"> <img src="https://avatars.githubusercontent.com/u/9844254?v=4" width="100;" alt="AhsanAyaz"/> <br /> <sub><b>Muhammad Ahsan Ayaz</b></sub> </a> </td> <td align="center"> <a href="https://github.com/OvidijusStukas"> <img src="https://avatars.githubusercontent.com/u/9720553?v=4" width="100;" alt="OvidijusStukas"/> <br /> <sub><b>Ovidijus Stukas</b></sub> </a> </td> <td align="center"> <a href="https://github.com/qstiegler"> <img src="https://avatars.githubusercontent.com/u/2858579?v=4" width="100;" alt="qstiegler"/> <br /> <sub><b>Quirin Stiegler</b></sub> </a> </td> <td align="center"> <a href="https://github.com/raysuelzer"> <img src="https://avatars.githubusercontent.com/u/1176341?v=4" width="100;" alt="raysuelzer"/> <br /> <sub><b>Ray Suelzer</b></sub> </a> </td></tr> <tr> <td align="center"> <a href="https://github.com/probert94"> <img src="https://avatars.githubusercontent.com/u/18258317?v=4" width="100;" alt="probert94"/> <br /> <sub><b>Robert Pattis</b></sub> </a> </td> <td align="center"> <a href="https://github.com/broekema41"> <img src="https://avatars.githubusercontent.com/u/4007585?v=4" width="100;" alt="broekema41"/> <br /> <sub><b>Roland Broekema</b></sub> </a> </td> <td align="center"> <a href="https://github.com/swierzbicki"> <img src="https://avatars.githubusercontent.com/u/7196324?v=4" width="100;" alt="swierzbicki"/> <br /> <sub><b>Sebastian Wierzbicki </b></sub> </a> </td> <td align="center"> <a href="https://github.com/shenay-aydan"> <img src="https://avatars.githubusercontent.com/u/38660036?v=4" width="100;" alt="shenay-aydan"/> <br /> <sub><b>空</b></sub> </a> </td> <td align="center"> <a href="https://github.com/framasev"> <img src="https://avatars.githubusercontent.com/u/41595972?v=4" width="100;" alt="framasev"/> <br /> <sub><b>Stas Amasev</b></sub> </a> </td> <td align="center"> <a href="https://github.com/nischi"> <img src="https://avatars.githubusercontent.com/u/2036054?v=4" width="100;" alt="nischi"/> <br /> <sub><b>Thierry Nischelwitzer</b></sub> </a> </td></tr> <tr> <td align="center"> <a href="https://github.com/vlio20"> <img src="https://avatars.githubusercontent.com/u/4542641?v=4" width="100;" alt="vlio20"/> <br /> <sub><b>Vlad Ioffe</b></sub> </a> </td> <td align="center"> <a href="https://github.com/WX9yMOXWId"> <img src="https://avatars.githubusercontent.com/u/30053114?v=4" width="100;" alt="WX9yMOXWId"/> <br /> <sub><b>无</b></sub> </a> </td> <td align="center"> <a href="https://github.com/zpaynter"> <img src="https://avatars.githubusercontent.com/u/29746771?v=4" width="100;" alt="zpaynter"/> <br /> <sub><b>无</b></sub> </a> </td> <td align="center"> <a href="https://github.com/evoltafreak"> <img src="https://avatars.githubusercontent.com/u/11610680?v=4" width="100;" alt="evoltafreak"/> <br /> <sub><b>Joshua</b></sub> </a> </td> <td align="center"> <a href="https://github.com/lorenzbaier"> <img src="https://avatars.githubusercontent.com/u/64407215?v=4" width="100;" alt="lorenzbaier"/> <br /> <sub><b>无</b></sub> </a> </td> <td align="center"> <a href="https://github.com/ruekart"> <img src="https://avatars.githubusercontent.com/u/9154610?v=4" width="100;" alt="ruekart"/> <br /> <sub><b>无</b></sub> </a> </td></tr> </table> <!-- readme: contributors -end --> ## 如何使用?

在您的项目中安装 ngx-mat-select-search

npm install ngx-mat-select-search

在您的 app.module.ts 中导入 NgxMatSelectSearchModule

import { MatSelectModule } from '@angular/material'; import { NgxMatSelectSearchModule } from 'ngx-mat-select-search'; @NgModule({ imports: [ ... MatSelectModule, NgxMatSelectSearchModule ], }) export class AppModule {}

通过将 ngx-mat-select-search 组件放置在 <mat-option> 元素内,在 mat-select 元素中使用它:

<mat-form-field> <mat-select [formControl]="bankCtrl" placeholder="银行" #singleSelect> <mat-option> <ngx-mat-select-search [formControl]="bankFilterCtrl"></ngx-mat-select-search> </mat-option> <mat-option *ngFor="let bank of filteredBanks | async" [value]="bank"> {{bank.name}} </mat-option> </mat-select> </mat-form-field>

查看 https://github.com/bithost-gmbh/ngx-mat-select-search/tree/master/src/app/examples 中的示例,了解如何连接 ngx-mat-select-search 并过滤可用选项。 或者查看 https://github.com/bithost-gmbh/ngx-mat-select-search-example 以在独立应用中查看它。

模板驱动表单

您也可以在模板驱动表单中使用它,如下所示:

<ngx-mat-select-search ngModel (ngModelChange)="filterMyOptions($event)">

标签

要更改标签,请使用 API 部分中指定的输入,如下所示:

<ngx-mat-select-search [formControl]="bankFilterCtrl" placeholderLabel="查找银行..." noEntriesFoundLabel="未找到匹配的银行"></ngx-mat-select-search>

要使用 i18n API 进行标签翻译,请添加相应的 i18n-... 属性:

<ngx-mat-select-search [formControl]="bankFilterCtrl" placeholderLabel="查找银行..." i18n-placeholderLabel noEntriesFoundLabel="未找到匹配的银行" i18n-noEntriesFoundLabel></ngx-mat-select-search>

兼容性

当前版本

  • @angular/core: ^15.0.0 || ^16.0.0 || ^17.0.0 || ^18.0.0
  • @angular/material: ^15.0.0 || ^16.0.0 || ^17.0.0 || ^18.0.0MatSelectModule (@angular/material/select)

版本 6.0.0

  • @angular/core: ^15.0.0
  • @angular/material: ^15.0.0MatLegacySelectModule (@angular/material/legacy-select)

版本 5.0.0

  • @angular/core: ^12.0.0 || ^13.0.0 || ^14.0.0
  • @angular/material: ^12.0.0 || ^13.0.0 || ^14.0.0

版本 3.3.3

  • @angular/core: ^8.0.0 || ^9.0.0 || ^10.0.0 || ^11.0.0 || ^12.0.0 || ^13.0.0
  • @angular/material: ^8.0.0 || ^9.0.0 || ^10.0.0 || ^11.0.0 || ^12.0.0 || ^13.0.0

版本 1.8.0

  • @angular/core: ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0
  • @angular/material: ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0

API

MatSelectSearchComponent 实现了 ControlValueAccessor 接口。 此外,它还提供以下输入:

输入

/** 搜索占位符的标签 */ @Input() placeholderLabel = '搜索'; /** 搜索输入字段的类型 */ @Input() type = 'text'; /** 用于显示关闭图标的基于字体的图标 */ @Input() closeIcon = 'close'; /** 用于显示关闭图标的基于SVG的图标。如果设置,将覆盖closeIcon */ @Input() closeSvgIcon?: string;

/** 当未找到条目时显示的标签。如果不应显示消息,则设置为 null。 */ @Input() noEntriesFoundLabel = '未找到选项';

/**

  • 下拉菜单关闭后是否应清除搜索字段。
  • 对服务器端过滤很有用。参见 #3 */ @Input() clearSearchInput = true;

/** 是否显示搜索进行中的指示器 */ @Input() searching = false;

/** 禁用输入字段的初始聚焦 */ @Input() disableInitialFocus = false;

/** 启用按 Esc 键清除输入 */ @Input() enableClearOnEscapePressed = false;

/**

  • 防止 Home / End 键传播到 mat-select,
  • 允许在搜索输入内移动光标,而不是导航选项 */ @Input() preventHomeEndKeyPropagation = false;

/** 当选项列表变化时禁用滚动到活动选项。对服务器端搜索很有用 */ @Input() disableScrollToActiveOnOptionsChanged = false;

/** 为搜索框添加 508 屏幕阅读器支持 */ @Input() ariaLabel = '下拉搜索';

/** 是否显示全选复选框(适用于 mat-select[multi=true]) */ @Input() showToggleAllCheckbox = false;

/** 全选复选框选中状态 */ @Input() toggleAllCheckboxChecked = false;

/** 全选复选框不确定状态 */ @Input() toggleAllCheckboxIndeterminate = false;

/** 在全选复选框的工具提示中显示消息 */ @Input() toggleAllCheckboxTooltipMessage = '';

/** 定义全选复选框工具提示的位置 */ @Input() toggleAllCheckboxTooltipPosition: 'left' | 'right' | 'above' | 'below' | 'before' | 'after' = 'below';

/** 显示/隐藏搜索输入的清除按钮 */ @Input() hideClearSearchButton = false;

/**

  • 在多选模式下始终在 selectionChange 时恢复选中的选项(例如用于懒加载/无限滚动)。
  • 默认为 false,因此只在过滤活动时恢复选中的选项。 */ @Input() alwaysRestoreSelectedOptionsMulti = false;

/** 输出事件发射器,用于向父组件发送全选布尔值 */ @Output() toggleAll = new EventEmitter<boolean>();


#### 自定义清除图标
为了自定义搜索图标,将 `ngxMatSelectSearchClear` 添加到您的自定义清除项(一个 `mat-icon` 或任何其他元素)并将其放置在 `ngx-mat-select-search` 组件内:
```html
<ngx-mat-select-search>
   <mat-icon ngxMatSelectSearchClear>delete</mat-icon>
</ngx-mat-select-search>

如果只需要更改图标,可以使用 closeIconcloseSvgIcon 输入。

自定义未找到条目元素

为了自定义未找到条目元素,将 ngxMatSelectNoEntriesFound 添加到您的自定义项(一个 mat-iconspanbutton 或任何其他元素)并将其放置在 ngx-mat-select-search 组件内:

<ngx-mat-select-search> <span ngxMatSelectNoEntriesFound> 未找到条目 <button mat-button color="primary"> 添加 <mat-icon>add</mat-icon> </button> </span> </ngx-mat-select-search>

自定义内容

带有 CSS 类 mat-select-search-custom-header-content 的自定义内容可以如下嵌入:

<ngx-mat-select-search> <div class="mat-select-search-custom-header-content">特殊内容</div> </ngx-mat-select-search>

全局默认选项

通过提供 MAT_SELECTSEARCH_DEFAULT_OPTIONS 注入令牌,可以全局设置 MatSelectSearchComponent 的多个 @Input() 属性的默认值。 请参阅 MatSelectSearchComponent 中相应 @Input() 属性的文档。

示例:

import { MAT_SELECTSEARCH_DEFAULT_OPTIONS, MatSelectSearchOptions } from 'ngx-mat-select-search'; @NgModule({ ... providers: [ { provide: MAT_SELECTSEARCH_DEFAULT_OPTIONS, useValue: <MatSelectSearchOptions>{ closeIcon: 'delete', noEntriesFoundLabel: '未找到选项', } } ] }) class AppModule {}

已知问题

  • 当打开选项面板并且面板位于屏幕边缘时,当前选中的选项可能被隐藏在搜索输入字段下方。

开发

本项目使用 Angular CLI 版本 1.7.1 生成。

开发服务器

运行 ng serve 启动开发服务器。导航到 http://localhost:4200/。如果您更改任何源文件,应用程序将自动重新加载。

构建

运行 ng build 构建项目。构建产物将存储在 dist/ 目录中。使用 -prod 标志进行生产构建。

库构建 / NPM 包

运行 npm run build-lib 构建库并生成 NPM 包。 构建产物将存储在 dist-lib/ 文件夹中。

运行单元测试

运行 npm run test 通过 Karma 执行单元测试。

编辑推荐精选

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
蛙蛙写作

蛙蛙写作

AI小说写作助手,一站式润色、改写、扩写

蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。

AI辅助写作AI工具蛙蛙写作AI写作工具学术助手办公助手营销助手AI助手
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

下拉加载更多