选择2 在 MVC 中设置多选值

Select2 Set Values for Multi-Select in MVC

本文关键字:设置 MVC 选择      更新时间:2023-09-26

我正在做一个在部分表单上使用 select2 多选的项目。此代码非常适合"创建"页面,但是当我转到"编辑"页面时,遇到了问题。我希望能够获取创建"项目"时的值,然后使用 jQuery 在"编辑"页面上为这些"项目"设置值。

这是我所拥有的:

var re = /[0-9]+$/;
$('#Item').select2({
    theme: "bootstrap",
    placeholder: "Not Set",
    tags: true
});
$('#Item').on("select2:select", function (evt) {
    var element = evt.params.data.element;
    var $element = $(element);
    $element.detach();
    $(this).append($element);
    $(this).trigger("change");
});
var values = "@Model.ItemIds"; //pull ItemIds from Model in MVC
$.each(values.split(","), function (i, e) {
    if (e != "Not Set" && e != "" && e != null && e != undefined) {
        if (!re.test(e)) {
            var newList = $.merge($('#Item').select2('data'), [{
                id: e,
                tag: e
            }]);
            $("#Item").select2('data', newList);
            $("#Item").append('<option value="' + e + '">' + e + '</option>');
        }
    $("#Item option[value=" + e + "]").prop("selected", true);
    }
});

因此,发生的情况是,当页面加载时,我得到选择的项目是@Model.ItemIds中的项目,但它们的排列顺序是<select>下的顺序,而不是它们在@Model.ItemIds.的顺序 任何帮助将不胜感激。谢谢!

这是我

的新代码:

var values = "@Model.ItemIds"; //pull ItemIds from Model in MVC
$.each(values.split(","), function (i, e) {
    if (e != "Not Set" && e != "" && e != null && e != undefined) {
        if (!re.test(e)) {
            var newList = $.merge($('#Item').select2('data'), [{
                id: e,
                tag: e
            }]);
            $("#Item").select2('data', newList);
            $("#Item").append('<option value="' + e + '">' + e + '</option>');
        }
        else{
            $("#Item").append($("#Item option[value='" + e + "']"));
        }
    $("#Item option[value='" + e + "']").prop("selected", true);
    }
});

将现有选项附加到末尾似乎已经解决了我的问题。