配置项与方法
配置项
参数 |
说明 |
类型 |
可选值 |
默认值 |
el |
渲染对象, css选择器, dom元素 |
string |
- |
- |
language |
语言选择 |
string |
zn / en |
zn |
data |
显示的数据 |
array |
- |
[ ] |
content |
自定义下拉框html |
string |
- |
- |
initValue |
初始化选中的数据, 需要在data中存在 |
array |
- |
null |
tips |
默认提示, 类似于placeholder |
string |
- |
请选择 |
empty |
空数据提示 |
string |
- |
暂无数据 |
filterable |
是否开启搜索 |
boolean |
true / false |
false |
searchTips |
搜索提示 |
string |
- |
请选择 |
delay |
搜索延迟 ms |
int |
- |
500 |
filterMethod |
搜索回调函数 |
function(val, item, index, prop) val: 当前搜索值, item: 每个option选项, index: 位置数据中的下标, prop: 定义key |
- |
- |
filterDone |
搜索完成函数 |
function(val, list) val: 当前搜索值, list: 过滤后的数据 |
- |
- |
remoteSearch |
是否开启自定义搜索 (远程搜索) |
boolean |
true / false |
false |
remoteMethod |
自定义搜索回调函数 |
function(val, cb, show, pageIndex) val: 当前搜索值, cb(arr, totalPage): 回调函数, 需要回调一个数组, 结构同data, 远程分页需要第二个参数: 总页码, show: 下拉框显示状态, pageIndex: 分页下当前页码 |
- |
- |
direction |
下拉方向 |
string |
auto / up / down |
auto |
style |
自定义样式 |
object |
- |
{ } |
height |
默认最大高度 |
string |
- |
200px |
paging |
是否开启自定义分页 |
boolean |
true / false |
false |
pageSize |
分页条数 |
int |
- |
10 |
pageEmptyShow |
分页无数据是否显示 |
boolean |
true / false |
true |
pageRemote |
是否开启远程分页 |
boolean |
true / false |
true |
radio |
是否开启单选模式 |
boolean |
true / false |
false |
repeat |
是否开启重复性模式 |
boolean |
true / false |
false |
clickClose |
是否点击选项后自动关闭下拉框 |
boolean |
true / false |
false |
prop |
自定义属性名称, 具体看下表 |
object |
- |
|
theme |
主题配置, 具体看下表 |
object |
- |
|
model |
模型, 多选的展示方式, 具体见下表 |
object |
- |
|
iconfont |
自定义选中图标 |
object |
- |
|
show |
展开下拉的回调 |
function |
- |
- |
hide |
隐藏下拉的回调 |
function |
- |
- |
template |
自定义渲染选项 |
function({ item, sels, name, value }) |
- |
- |
on |
监听选中变化 |
function({ arr, change, isAdd }) |
- |
- |
max |
设置多选选中上限 |
int |
- |
0 |
maxMethod |
达到选中上限的回到 |
function(sels, item), sels: 已选中数据, item: 当前选中的值 |
- |
- |
name |
表单提交时的name |
string |
- |
select |
layVerify |
表单验证, 同layui的lay-verify |
string |
- |
'' |
layVerType |
表单验证, 同layui的lay-verType |
string |
- |
'' |
layReqText |
表单验证, 同layui的lay-reqText |
string |
- |
'' |
toolbar |
工具条, 具体看下表 |
object |
- |
- |
showCount |
展示在下拉框中的最多选项数量 |
int |
- |
0 |
enableKeyboard |
是否启用键盘操作选项 |
boolean |
true / false |
true |
enableHoverFirst |
是否默认选中第一项 |
boolean |
true / false |
true |
selectedKeyCode |
选中的键盘KeyCode |
int |
全部KeyCode, 也可xmSelect.KeyCode.Enter,xmSelect.KeyCode.Space |
13 |
autoRow |
是否开启自动换行(选项过多时) |
boolean |
true / false |
false |
size |
尺寸 |
string |
large / medium / small / mini |
medium |
disabled |
是否禁用多选 |
boolean |
true / false |
false |
create |
创建条目 |
function(val, data), val: 搜索的数据, data: 当前下拉数据 |
- |
null |
tree |
树形结构, 具体看下表 |
object |
- |
- |
cascader |
级联结构, 具体看下表 |
object |
- |
- |
submitConversion |
配置表单提交数据 |
function(sels, prop), sels: 已选中数据, prop: 自定义的prop |
- |
- |
done |
渲染完成回调 |
function |
- |
- |
prop
参数 |
说明 |
类型 |
可选值 |
默认值 |
name |
显示名称 |
string |
- |
name |
value |
选中值, 当前多选唯一 |
string |
- |
value |
selected |
是否选中 |
string |
- |
selected |
disabled |
是否禁用 |
string |
- |
disabled |
children |
分组children |
string |
- |
children |
optgroup |
分组optgroup |
string |
- |
optgroup |
分组说明
如果children属性为数组的时候开启分组模式
{name: '销售员', children: [
{name: '李四', value: 4, selected: true},
{name: '王五', value: 5},
]},
//可在分组上定义click属性, 来定义点击事件
{name: '选中', children: [...], click: 'SELECT'},
{name: '清空', children: [...], click: 'CLEAR'},
{name: '自动', children: [...], click: 'AUTO'},
{name: '自定义', children: [...], click: function(item){
alert('自定义的, 想干嘛干嘛');
}},
theme
参数 |
说明 |
类型 |
可选值 |
默认值 |
color |
主题颜色 |
string |
- |
#009688 |
maxColor |
选中上限闪烁边框颜色 |
string |
- |
#e54d42 |
hover |
键盘操作的背景色 |
string |
- |
#f2f2f2 |
model
目前仅配置label即可
model: {
//是否展示复选框或者单选框图标 show, hidden:变换背景色
icon: 'show',
label: {
//使用方式
type: 'block',
//使用字符串拼接的方式
text: {
//左边拼接的字符
left: '',
//右边拼接的字符
right: '',
//中间的分隔符
separator: ', ',
},
//使用方块显示
block: {
//最大显示数量, 0:不限制
showCount: 0,
//是否显示删除图标
showIcon: true,
//自定义渲染label, 默认渲染name, 回调参数(item, sels)
template: null,
},
//自定义文字
count: {
//函数处理
template(data, sels){
//data: 所有的数据
//sels: 选中的数据
return `已选中 ${sels.length} 项, 共 ${data.length} 项`
}
},
},
//展示类型, 下拉框形式: absolute, 直接显示模式: relative, 浮动布局: fixed
type: 'absolute',
},
iconfont
参数 |
说明 |
类型 |
可选值 |
默认值 |
select |
选中图标 |
string |
- |
- |
unselect |
非选中图标 |
string |
- |
- |
half |
半选图标 |
string |
- |
- |
parent |
父节点图标, 值为hidden时, 隐藏 |
string |
- |
- |
toolbar
参数 |
说明 |
类型 |
可选值 |
默认值 |
show |
是否展示工具条 |
boolean |
true / false |
false |
showIcon |
是否显示工具图标 |
boolean |
true / false |
true |
list |
工具条数组 (默认有 全选/清空, 可以自定义), 还有 REVERSE:反选 |
array |
ALL, CLEAR, REVERSE |
[ "ALL", "CLEAR" ] |
自定义方式
list: [ "ALL", "CLEAR",
{
//显示图标, 可以是layui内置的图标, 也可以是自己引入的图标
//传入的icon会转化为 <i class="layui-icon layui-icon-face-smile"></i>
icon: 'layui-icon layui-icon-face-smile',
//显示名称
name: 'xxx',
//点击时触发的回调
method: function(data){
//data 当前页面的数据
}
}
]
tree
参数 |
说明 |
类型 |
可选值 |
默认值 |
show |
是否展示为树状结构 |
boolean |
true / false |
false |
showFolderIcon |
是否显示节点前的三角图标 |
boolean |
true / false |
true |
showLine |
是否显示虚线 |
boolean |
true / false |
true |
indent |
间距 |
int |
- |
20 |
expandedKeys |
默认展开的节点数组, 为true时展开所有节点 |
array / boolean |
- |
[ ] |
strict |
是否遵循严格父子结构 |
boolean |
true / false |
true |
simple |
是否开启极简模式 |
boolean |
true / false |
false |
nodeType |
标注节点类型的key |
string |
leaf: 叶子节点, parent: 父节点, half: 半选节点 |
__node_type |
clickExpand |
点击节点是否展开, false时点击三角箭头进行展开操作 |
boolean |
true / false |
true |
clickCheck |
点击节点是否选中, false时点击复选框进行选中操作 |
boolean |
true / false |
true |
cascader
参数 |
说明 |
类型 |
可选值 |
默认值 |
show |
是否展示为级联结构 |
boolean |
true / false |
false |
indent |
每一级的宽度 |
int |
- |
100 |
strict |
是否遵循严格父子结构 |
boolean |
true / false |
true |
全局方法
事件名 |
说明 |
参数 |
返回值 |
render |
渲染多选 |
(options: 配置项) |
实例对象 |
get |
获取页面中已经渲染的多选 |
(filter: 过滤el , single: 是否返回单实例) |
符合条件的实例数组 |
batch |
批量操作已渲染的多选 |
(filter: 过滤el , method: 方法, ...方法参数) |
符合条件的实例数组 |
arr2tree |
把列表数据转化为树状结构 |
(arr: 数据, pid: 父节点ID的key, id: 对应key, children: 对应key, topParentId: 顶级节点的ID) |
符合条件的数组 |
//render 使用方式
xmSelect.render(OPTIONS);
//get 使用方式
xmSelect.get('#demo1'); //指定某一个获取
xmSelect.get(/.*demo1.*/); //正则获取
//自定义方法获取
xmSelect.get(function(el){
return el == '#demo1' || el == '#demo2';
});
//单实例
xmSelect.get('#demo2', true);
//batch 使用方式
//批量执行禁用
xmSelect.batch(/.*demo/, 'update', {
disabled: true,
});
//批量执行warning
xmSelect.batch(/.*demo/, 'warning', '#F00', true);
实例方法
:::warning
xmSelect.render()后会返回一个xmSelect对象, 可以进行方法调用
:::
事件名 |
说明 |
参数 |
getValue |
获取当前选中的数据 |
(type: 类型), 可选值: name, nameStr, value, valueStr |
setValue |
动态设置数据 |
(array: 选中的数据, show: 是否展开下拉,不传默认当前显示状态,取值: true/false, listenOn: 是否触发on的监听, 默认false) |
append |
追加赋值 |
(array: 追加的数据) |
delete |
删除赋值 |
(array: 删除的数据) |
opened |
主动展开下拉 |
- |
closed |
主动关闭下拉 |
- |
reset |
重置为上一次的render状态 |
- |
update |
更新多选选中, reset不保留 |
(options: 见配置项) |
warning |
警告 |
(color: 默认同theme.maxColor, sustain: 是否持续显示) |
getTreeValue |
树节点模式下获取数据, v1.2.0 新增 |
(leafOnly: 是否只是叶子节点,默认值为 false, includeHalfChecked: 是否包含半选节点,默认值为 false) |
changeExpandedKeys |
树模式下更新节点展开状态, v1.2.0 新增 |
(keys: true-全部展开, false-全部关闭, 数组-展开的节点值) |
enable |
启用选项, disabled=false, v1.2.0 新增 |
(array: 想要启用的选项数组) |
disable |
禁用用选项, disabled=true, v1.2.0 新增 |
(array: 想要禁用的选项数组) |
calcPosition |
fixed布局模式下重新计算位置, v1.2.2 新增 |
- |