如何快速实现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生态中最受欢迎的多选解决方案之一。无论是简单的城市选择还是复杂的权限配置,都能提供出色的用户体验和开发效率。立即集成到你的项目中,提升表单交互体验吧! 🎉
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
