Angular9 NG-ZORRO 9 复选框组合最佳实践

背景

  • Angular 9 + NG-ZORRO 9
  • 需要一组复选框,支持:
    • 自定义布局(多列显示)
    • 获取选中值(直接拿 value 数组,不用遍历)
    • 弹窗关闭时一键清空

核心数据

用于显示多选框

typescript 复制代码
options = [
    { label: 'A', value: 1, checked: false },
    { label: 'B', value: 2, checked: false },
    { label: 'C', value: 4, checked: false },
    { label: 'D', value: 8, checked: false },
  ];

数据输出

typescript 复制代码
detectionStartChange(value: number[], popDetectionStart) {
	console.log(value);
}

关闭弹窗

关闭弹窗清空选中项

typescript 复制代码
closeModal() {
    this.options.forEach((item) => item.checked = false);
  }

模板文件HTML

使用 nz-checkbox-group

html 复制代码
<nz-checkbox-group style="width: 100%;" [(ngModel)]="options"
	(ngModelChange)="detectionStartChange($event, popDetectionStart)">
</nz-checkbox-group>

使用 nz-checkbox-wrapper

html 复制代码
<nz-checkbox-wrapper style="width: 100%;" (nzOnChange)="detectionStartChange($event, popDetectionStart)">
	<div nz-row>
		<div nz-col nzSpan="12" *ngFor="let data of options">
		<label nz-checkbox [nzChecked]="data.checked" 
			[nzValue]="data.value">{{data.label}}</label>
		</div>
	</div>
</nz-checkbox-wrapper>

技术总结

nz-checkbox-group和nz-checkbox-wrapper都能实现多选功能,但是核心差异是: nz-checkbox-group输出的数据事整个options,需要遍历options拿到checked为true的选项,并获取其value值,而且不支持nz-zorro的响应式布局; nz-checkbox-wrapper输出的数据直接就是1, 2类似的value数组,并且支持nz-zorro的响应式布局。

相关推荐
starrysky8102 天前
AI 助手调试踩坑:5 轮瞎猜定位 4s budget 兜底路径(含 Hindsight 反思账本使用指南)
angular.js
LiuJun2Son2 天前
Angular 快速入门:服务和依赖注入
前端·javascript·angular.js
weixin_li152********3 天前
《Angular 中优雅地处理枚举值:Map + *ngIf as 替代多次 *ngIf》
javascript·vue.js·angular.js
LiuJun2Son4 天前
Angular 快速入门:从零搭建你的第一个应用
前端·javascript·angular.js
starrysky8106 天前
Hindsight 记忆系统 recall 接口 60 秒不返回?——5 层根因诊断 + bge-m3 切换 + 9419 条数据重建 + 本地 100ms 召回完整实战
angular.js
starrysky8107 天前
你的记忆系统在腐烂:Hindsight consolidation机制解剖——从去重原理到生产配置
angular.js
starrysky8108 天前
Hermes Gateway重启慢到让人砸键盘:从journalctl到cProfile,三层根因逐层拆解实录
程序员·angular.js
ejinxian8 天前
Angular v22 正式发布:Signal Forms、Angular Aria 和 AI 开发工具全面生产化
前端·javascript·angular.js
starrysky81013 天前
Linux 下 Qt 应用无障碍自动化:记一次WX无人值守系统的架构演进
angular.js