updateSelect 支持指定 id

This commit is contained in:
fofolee
2020-07-13 20:35:03 +08:00
parent 49c6e6b536
commit b248980bc6

View File

@@ -235,26 +235,25 @@ quickcommand = {
}, },
// 更新选项列表 // 更新选项列表
updateSelectList: function (selects) { updateSelectList: function (opt, id) {
if(!$('#selectBox').length) throw '当前没有选择列表, 请结合 quickcommand.showSelectList 使用' if(!$('#selectBox').length) throw '当前没有选择列表, 请结合 quickcommand.showSelectList 使用'
let data = $('#selectBox').data('options') let data = $('#selectBox').data('options')
let num = data.length let num = data.length
typeof id == 'undefined' && (id = num)
if (id > num) throw 'id 不能大于当前列表数'
let optionType = $('#selectBox').data('type') let optionType = $('#selectBox').data('type')
selects instanceof Array || (selects = [selects]) let item = { id: id }
let item
selects.forEach(s => {
item = {id: num++}
if (optionType == 'json') { if (optionType == 'json') {
item.text = '' item.text = ''
Object.keys(s).forEach(k => item[k] = s[k]) if (!(opt instanceof Object)) throw '更新的选项格式与当前的不一致'
s.icon && (item.text += `<div class="icon"><img src="${s.icon}"></div>`) Object.keys(opt).forEach(k => item[k] = opt[k])
s.title && (item.text += `<div class="title">${s.title}</div>`) opt.icon && (item.text += `<div class="icon"><img src="${opt.icon}"></div>`)
s.description && (item.text += `<div class="description">${s.description}</div>`) opt.title && (item.text += `<div class="title">${opt.title}</div>`)
opt.description && (item.text += `<div class="description">${opt.description}</div>`)
} else { } else {
item.text = s item.text = opt
} }
data.push(item) data[id] && (data[id] = item) || data.push(item)
})
$('#selectBox').data('options', data).val(null).trigger('change') $('#selectBox').data('options', data).val(null).trigger('change')
$("#quickselect .select2-search__field").trigger('input') $("#quickselect .select2-search__field").trigger('input')
modWindowHeight($('.select2-results').outerHeight()) modWindowHeight($('.select2-results').outerHeight())