如何快速实现Layui多选下拉框:formSelects插件的终极指南 🚀
formSelects是一款基于Layui框架开发的高效多选下拉框插件,专为解决复杂表单中的多选需求而设计。无论是基础的城市选择、商品分类筛选,还是动态加载的远程数据多选,这款插件都能提供流畅的交互体验和灵活的配置选项,让开发者轻松实现媲美原生控件的多选功能。
🌟 核心功能亮点
✅ 强大多选能力
支持无限层级分组展示选项,轻松应对商品分类、权限管理等复杂场景。通过直观的标签式选中效果,用户可以清晰查看已选项并快速取消选择,提升表单填写效率。
⚡ 高效搜索过滤
内置拼音检索功能,支持首字母、全拼、简拼等多种搜索方式。例如输入"bj"即可快速定位"北京"选项,配合防抖处理,确保大量数据下依然保持流畅响应。
📊 动态数据加载
提供灵活的数据源配置,支持本地数组、JSON文件和AJAX远程加载。支持自定义参数传递和数据格式化,轻松对接后端API接口,实现动态数据渲染。
🎨 个性化外观定制
内置多种皮肤样式,可通过CSS变量自定义边框、颜色、间距等样式属性。支持下拉框高度、最大显示标签数量等布局配置,完美适配不同UI设计需求。
🛠️ 丰富交互事件
提供选择变更、搜索触发、下拉框显示/隐藏等完整事件回调,方便开发者实现联动表单、实时数据验证等高级功能。支持通过API动态更新选项数据和配置参数。
📸 界面展示

图1:formSelects多选框默认样式展示,包含已选标签、搜索框和下拉选项列表
🚀 快速上手指南
🔧 环境准备
确保项目中已引入Layui框架(推荐v2.2.6及以上版本),项目结构中layui资源路径为:UI/layui-v2.2.6/
📦 安装插件
- 从仓库克隆源码:
git clone https://gitcode.com/gh_mirrors/la/layui-formSelects
- 引入核心文件到HTML页面:
<!-- 引入Layui核心样式 -->
<link rel="stylesheet" href="UI/layui-v2.2.6/layui/css/layui.css">
<!-- 引入formSelects插件 -->
<script src="src/formSelects-v4.js"></script>
⚡ 基础使用示例
- 创建HTML结构:
<div class="layui-form-item">
<label class="layui-form-label">城市选择</label>
<div class="layui-input-block">
<select id="citySelect" multiple lay-filter="cityFilter">
<option value="bj">北京</option>
<option value="sh" selected>上海</option>
<option value="gz">广州</option>
<option value="sz" selected>深圳</option>
</select>
</div>
</div>
- 初始化插件:
layui.use(['form', 'formSelects'], function() {
var form = layui.form;
var formSelects = layui.formSelects;
// 渲染多选框
formSelects.render({
elem: '#citySelect', // 绑定元素
max: 3, // 最多选择3项
placeholder: '请选择城市' // 占位提示文字
});
// 监听选择事件
formSelects.on('cityFilter', function(data){
console.log('选中值:', data.elem.val());
});
form.render();
});
📚 高级配置指南
🔍 自定义搜索功能
formSelects.render({
elem: '#productSelect',
search: true, // 开启搜索
searchPlaceholder: '输入商品名称搜索',
searchUrl: '/api/product/search', // 远程搜索接口
searchName: 'keyword', // 搜索参数名
searchSuccess: function(data){
// 格式化返回数据
return data.map(item => ({
name: item.productName,
value: item.productId,
disabled: item.stock <= 0
}));
}
});
📂 分组数据配置
// 本地分组数据
var categoryData = [
{
name: '电子产品',
children: [
{name: '手机', value: 'phone'},
{name: '电脑', value: 'computer'}
]
},
{
name: '家用电器',
children: [
{name: '冰箱', value: 'fridge'},
{name: '洗衣机', value: 'washer'}
]
}
];
formSelects.render({
elem: '#categorySelect',
data: categoryData, // 分组数据源
isGroup: true, // 启用分组模式
groupIcon: true // 显示分组图标
});
📝 常见问题解决
🔄 动态更新数据
当需要根据其他表单值动态更新选项时,可使用reload方法:
// 动态加载用户列表
function loadUserList(departmentId) {
formSelects.reload('userSelect', {
url: '/api/users',
params: {deptId: departmentId},
success: function(data){
// 数据加载完成回调
console.log('用户数据加载完成');
}
});
}
📱 移动端适配
通过配置mobile参数启用移动端模式,优化触摸操作体验:
formSelects.render({
elem: '#mobileSelect',
mobile: true, // 启用移动端模式
height: '200px', // 下拉框高度
trigger: 'click' // 点击触发下拉
});
📚 资源参考
- 完整API文档:docs/
- 示例代码:example/example_v4.html
- 核心源码:src/formSelects-v4.js
- 主题样式:UI/layui-v2.2.6/layui/css/
💡 使用技巧
- 性能优化:当选项数量超过1000条时,建议启用分页加载或远程搜索模式
- 表单提交:选中值会自动同步到原始select元素,可直接通过form表单提交
- 数据回显:编辑表单时,通过设置select元素的selected属性即可自动回显已选值
- 冲突解决:若与其他插件存在样式冲突,可通过增加自定义类名隔离样式
formSelects插件凭借其轻量化设计(核心JS仅30KB)和强大功能,已成为Layui生态中最受欢迎的多选解决方案之一。无论是简单的城市选择还是复杂的权限配置,都能提供出色的用户体验和开发效率。立即集成到你的项目中,提升表单交互体验吧! 🎉
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0194
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0121
MiMo-V2.5-Pro-FP4-DFlashMiMo-V2.5-Pro-FP4-DFlash 是驱动 MiMo-V2.5-Pro-UltraSpeed 的底层模型: FP4 量化骨干网络:对 MoE 专家采用 MXFP4 量化,同时保持模型其他部分的更高精度,在几乎无损质量的前提下,显著减小模型体积并降低内存带宽压力。 BF16 DFlash 草稿生成器:用于块扩散推测解码,每次前向传播可生成一整个块的 tokens,并让骨干网络一步完成验证。 两者协同作用,既降低了每参数的位宽,又减少了骨干网络前向传播的次数,而这两者正是万亿参数模型解码过程中的两大主要成本来源。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
AstrBot✨ 易上手的多平台 LLM 聊天机器人及开发框架 ✨ 平台支持 QQ、QQ频道、Telegram、微信、企微、飞书 | OpenAI、DeepSeek、Gemini、硅基流动、月之暗面、Ollama、OneAPI、Dify 等。附带 WebUI。Python05
handy-ollama动手学Ollama,CPU玩转大模型部署,在线阅读地址:https://datawhalechina.github.io/handy-ollama/Jupyter Notebook06
