首页
/ Choices.js 自定义模板中 classNames 参数的正确使用方式

Choices.js 自定义模板中 classNames 参数的正确使用方式

2025-06-02 08:16:13作者:尤辰城Agatha

问题背景

在使用 Choices.js 这个强大的 JavaScript 选择框库时,开发者经常需要通过 callbackOnCreateTemplates 回调函数来自定义下拉选项的渲染模板。然而,在自定义 choice 模板时,许多开发者会遇到 classNames 参数未定义的问题,这会导致样式无法正确应用。

问题现象

开发者尝试在 callbackOnCreateTemplates 中自定义 choice 模板时,发现直接使用 classNames 参数会导致所有类名属性为 undefined。而当将参数改为解构形式 {classNames} 时,问题得到解决。

技术分析

参数传递机制

Choices.js 在调用 callbackOnCreateTemplates 中的各个模板函数时,对于不同模板类型的参数传递方式有所不同:

  1. item 模板:直接传递两个参数 (classNames, data)
  2. choice 模板:传递一个包含多个属性的对象,需要使用解构语法 ({classNames}, data)

这种不一致性源于 Choices.js 内部实现的历史原因,虽然不够统一,但了解这一差异能帮助开发者正确使用。

正确的参数解构方式

对于 choice 模板,正确的参数接收方式应该是:

choice: ({classNames}, data) => {
  // 模板逻辑
}

这种解构赋值的方式能够正确地从第一个参数对象中提取出 classNames 属性。

解决方案

1. 统一使用解构语法

为了避免混淆,建议在所有模板函数中都使用解构语法:

callbackOnCreateTemplates: {
  item: ({classNames}, data) => { /* ... */ },
  choice: ({classNames}, data) => { /* ... */ }
}

2. 类名使用的最佳实践

Choices.js 提供的 classNames 对象包含以下常用类名:

  • item: 基础项样式
  • itemChoice: 选择项特有样式
  • itemDisabled: 禁用状态样式
  • itemSelectable: 可选状态样式
  • highlightedState: 高亮状态样式

在模板中合理组合这些类名可以确保样式与库的默认行为保持一致。

3. 自定义模板示例

结合正确的参数解构和类名使用,一个完整的自定义模板示例如下:

callbackOnCreateTemplates: {
  choice: ({classNames}, data) => {
    return `
      <div class="${classNames.item} ${classNames.itemChoice} ${
        data.disabled ? classNames.itemDisabled : classNames.itemSelectable
      }" data-choice data-id="${data.id}" data-value="${data.value}">
        <span style="background-color:${data?.customProperties?.color};"></span>
        ${data.label}
      </div>
    `;
  },
  item: ({classNames}, data) => {
    return `
      <div class="${classNames.item} ${
        data.highlighted ? classNames.highlightedState : classNames.itemSelectable
      }" data-item data-id="${data.id}" data-value="${data.value}">
        <span style="background-color:${data?.customProperties?.color};"></span>
        ${data.label}
      </div>
    `;
  }
}

总结

Choices.js 中不同模板函数的参数传递方式存在差异,特别是在处理 classNames 时。通过使用解构语法和了解库的内部实现机制,开发者可以避免类名未定义的问题,创建出既美观又功能完善的自定义选择框组件。记住这一细微差别,将大大提高使用 Choices.js 进行开发的效率。

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
867
513
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
265
305
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
598
57
GitNextGitNext
基于可以运行在OpenHarmony的git,提供git客户端操作能力
ArkTS
10
3