gpt4 book ai didi

jquery - 有 jQuery jEditable 多选插件吗?

转载 作者:行者123 更新时间:2023-12-01 01:30:22 25 4
gpt4 key购买 nike

我正在使用优秀的jEditable用于在我的页面上进行一些就地编辑的插件。有一个地方我需要一个多选元素。有没有 jEditable 插件可以让我做到这一点?

我一直在尝试使用 jEditable作者的插件 API 来创建我自己的多选插件,但到目前为止还没有骰子。关于 API 中每个函数的作用似乎没有足够的文档。他提供的每个示例插件似乎都依赖于其他 jQuery 插件。我只需要一个基本的多选元素...

最佳答案

我对 Kalyan 的建议做了一个小补丁,导致它在没有可选的“selected”选项的情况下无法工作,并对大小属性进行了硬编码。然后我将其修改为 jEditable 插件,而不是必须粘贴到 jEditable 本身中的东西。我目前正在客户网站上使用它,尽管我只使用它由 json 字符串填充,因此其他方法可能仍然存在错误。

$.editable.addInputType("multiselect", {
element: function (settings, original) {
var select = $('<select multiple="multiple" />');

if (settings.width != 'none') { select.width(settings.width); }
if (settings.size) { select.attr('size', settings.size); }

$(this).append(select);
return (select);
},
content: function (data, settings, original) {
/* If it is string assume it is json. */
if (String == data.constructor) {
eval('var json = ' + data);
} else {
/* Otherwise assume it is a hash already. */
var json = data;
}
for (var key in json) {
if (!json.hasOwnProperty(key)) {
continue;
}
if ('selected' == key) {
continue;
}
var option = $('<option />').val(key).append(json[key]);
$('select', this).append(option);
}

if ($(this).val() == json['selected'] ||
$(this).html() == $.trim(original.revert)) {
$(this).attr('selected', 'selected');
}

/* Loop option again to set selected. IE needed this... */
$('select', this).children().each(function () {
if (json.selected) {
var option = $(this);
$.each(json.selected, function (index, value) {
if (option.val() == value) {
option.attr('selected', 'selected');
}
});
} else {
if (original.revert.indexOf($(this).html()) != -1)
$(this).attr('selected', 'selected');
}
});
}
});

关于jquery - 有 jQuery jEditable 多选插件吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1597756/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com