https://github.com/bithost-gmbh/ngx-mat-select-search
这是一个Angular组件,为Angular Material库的MatSelect选项提供一个输入字段用于搜索/过滤。
<img src="https://yellow-cdn.veclightyear.com/0a4dffa0/ffb36202-5719-49fc-a20b-67e63a138f27.png" alt="示例" width="293"/>在以下链接可以看到实际效果:
https://stackblitz.com/github/bithost-gmbh/ngx-mat-select-search-example
查看示例代码,在浏览器中构建,最新版本,最新Material版本
https://bithost-gmbh.github.io/ngx-mat-select-search/
预构建,最新版本,较旧的Material版本,可在移动设备上运行
重要提示:本项目是https://github.com/angular/material2/issues/5697的临时实现。 最终目标是在官方Angular Material仓库中实现,将创建一个新的PR。
欢迎贡献,请开启一个issue,最好提交一个pull request。
我们致力于通过不断改进NgxMatSelectSearch
并快速响应错误报告来提供最佳服务。我们完全免费提供这些服务。
如果您觉得这个库对您有用,为您和您的业务节省了宝贵的时间,请考虑捐赠以支持其维护和进一步开发。
非常感谢我们的财务支持者!
<!-- 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: 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.0
与 MatSelectModule
(@angular/material/select
)6.0.0
@angular/core
: ^15.0.0
@angular/material
: ^15.0.0
与 MatLegacySelectModule
(@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
MatSelectSearchComponent
实现了 ControlValueAccessor 接口。
此外,它还提供以下输入:
/** 搜索占位符的标签 */ @Input() placeholderLabel = '搜索'; /** 搜索输入字段的类型 */ @Input() type = 'text'; /** 用于显示关闭图标的基于字体的图标 */ @Input() closeIcon = 'close'; /** 用于显示关闭图标的基于SVG的图标。如果设置,将覆盖closeIcon */ @Input() closeSvgIcon?: string;
/** 当未找到条目时显示的标签。如果不应显示消息,则设置为 null。 */ @Input() noEntriesFoundLabel = '未找到选项';
/**
/** 是否显示搜索进行中的指示器 */ @Input() searching = false;
/** 禁用输入字段的初始聚焦 */ @Input() disableInitialFocus = false;
/** 启用按 Esc 键清除输入 */ @Input() enableClearOnEscapePressed = 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;
/**
/** 输出事件发射器,用于向父组件发送全选布尔值 */ @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>
如果只需要更改图标,可以使用 closeIcon
和 closeSvgIcon
输入。
为了自定义未找到条目元素,将 ngxMatSelectNoEntriesFound
添加到您的自定义项(一个 mat-icon
、span
、button
或任何其他元素)并将其放置在 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 run build-lib
构建库并生成 NPM 包。
构建产物将存储在 dist-lib/
文件夹中。
运行 npm run test
通过 Karma 执行单元测试。
字节跳动发布的AI编程神器IDE
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
AI小说写作助手,一站式润色、改写、扩写
蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。
全能AI智能助手,随时解答生活与工作的多样问题
问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。
实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。
一键生成PPT和Word,让学习生活更轻松
讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。
深度推理能力全新升级,全面对标OpenAI o1
科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。