如何快速实现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生态中最受欢迎的多选解决方案之一。无论是简单的城市选择还是复杂的权限配置,都能提供出色的用户体验和开发效率。立即集成到你的项目中,提升表单交互体验吧! 🎉
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
请把这个活动推给顶尖程序员😎本次活动专为懂行的顶尖程序员量身打造,聚焦AtomGit首发开源模型的实际应用与深度测评,拒绝大众化浅层体验,邀请具备扎实技术功底、开源经验或模型测评能力的顶尖开发者,深度参与模型体验、性能测评,通过发布技术帖子、提交测评报告、上传实践项目成果等形式,挖掘模型核心价值,共建AtomGit开源模型生态,彰显顶尖程序员的技术洞察力与实践能力。00
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
MiniMax-M2.5MiniMax-M2.5开源模型,经数十万复杂环境强化训练,在代码生成、工具调用、办公自动化等经济价值任务中表现卓越。SWE-Bench Verified得分80.2%,Multi-SWE-Bench达51.3%,BrowseComp获76.3%。推理速度比M2.1快37%,与Claude Opus 4.6相当,每小时仅需0.3-1美元,成本仅为同类模型1/10-1/20,为智能应用开发提供高效经济选择。【此简介由AI生成】Python00
Qwen3.5Qwen3.5 昇腾 vLLM 部署教程。Qwen3.5 是 Qwen 系列最新的旗舰多模态模型,采用 MoE(混合专家)架构,在保持强大模型能力的同时显著降低了推理成本。00- RRing-2.5-1TRing-2.5-1T:全球首个基于混合线性注意力架构的开源万亿参数思考模型。Python00
