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的响应式布局。

相关推荐
starrysky8101 天前
MemAvailable 还有 29GB,系统却报内存压力?——Ubuntu 24.04 CIFS 内核 Page Cache 泄漏排查实录
angular.js
starrysky8101 天前
KeyError: 'xxx' —— 字典里没这个键,但你的代码以为有
angular.js
starrysky8101 天前
FP8量化实战:vLLM与SGLang部署DeepSeek显存减半、吞吐翻倍——Agent推理引擎篇(二)
angular.js
starrysky8101 天前
vLLM与SGLang启动参数调优实战:从默认配置到生产级吞吐量翻倍——Agent推理引擎篇
angular.js
starrysky8102 天前
【03】ImportError: cannot import name 'X' —— 模块在,名字没了
angular.js
starrysky8102 天前
systemd-journald日志限速导致生产日志丢失:Suppressed XXXX messages完整排查
angular.js
Jolyne_3 天前
Angular基础速通
前端·angular.js
starrysky8103 天前
Agent 的终端安全怎么做?6 种沙箱后端 + 危险命令审批 + sudo 无痕处理的完整拆解
angular.js
starrysky8103 天前
Flash Attention 安装地狱六重崩溃:CUDA_HOME not set、undefined symbol、预编译轮子不兼容、pip 编译两小时失败——逐一击破
angular.js
starrysky8105 天前
nvidia-smi 显示 8GB 空闲,为什么 PyTorch 报 CUDA out of memory?——CUDA 缓存分配器底层原理
angular.js