ASP.NET Core MVC コントロールヘルプ
MultiSelectListBox
コントロールの使用 > Input > MultiSelectListBox

The MultiSelectListBox control is an advanced ListBox control that supports check boxes for each item, ability to select all items and a feature to filter the list. The control is represented by the MultiSelectListBox class which allows it to displays a list of items which may contain plain text or HTML, and allows users to select multiple items. The MultiSelectListBox class allows you to select all items in the list using the ShowSelectAllCheckbox property and filter the items using the ShowFilterInput property. In addition, it allows you to programmatically retrieve the checked items using the CheckedItems property.

MultiSelectListBox control showing a list of products.

The following example uses the Products table from NWind to show the list of products in the MultiSelectListBox control.

Controller

CellMarkerController.cs
コードのコピー
private C1NWindEntities db;
public ActionResult Index(FormCollection collection)
{
    return View(db.Products);
}

View for the Controller

Index.cshtml
コードのコピー
@model IEnumerable<Product>

    <div style="overflow: auto">
        <div class="col-md-5">
            <div id="multiSelectList" style="width:100%;max-width:400px;height:530px"></div>
        </div>
        <div class="col-md-7">
            <p>
                <b>Checked Items:</b>
            </p>
            <div style="height:500px; overflow-y:auto; border-top: 1px solid #eeeeee; border-bottom: 1px solid #eeeeee;">
                <ul id="checkedItems" class="col-md-5"></ul>
                <ul id="checkedItems1" class="col-md-5"></ul>
            </div>
        </div>
    </div>

    @section Scripts{
        <script>
            c1.documentReady(function () {
                let multiSelectList = wijmo.Control.getControl("#multiSelectList");
                checkedItemsChanged(multiSelectList);
            })
            // CheckedItemsChanged event handler
            function checkedItemsChanged(sender) {
                let html = '',
                    html1 = '',
                    items = sender.checkedItems,
                    n = items.length;
                if (n > 40) n = n / 2;
                else if (n > 20) n = 20;
                items.forEach(function (item) {
                    n--;
                    if (n >= 0) {
                        html += "<li>" + item.ProductName + "</li>";
                    } else {
                        html1 += "<li>" + item.ProductName + "</li>";
                    }
                });
                document.querySelector('#checkedItems').innerHTML = html;
                document.querySelector('#checkedItems1').innerHTML = html1;
            }
        </script>
    }

    <c1-multi-select-list-box id="multiSelectList" display-member-path="ProductName" checked-member-path="Discontinued"
                              show-select-all-checkbox="true" show-filter-input="true" checked-items-changed="checkedItemsChanged">
        <c1-items-source source-collection="Model"></c1-items-source>
    </c1-multi-select-list-box>

In addition, it lets you set the minimum number of rows and/or columns required to enable virtualization in the ListBox control using the VirtualizationThreshold property. For more information, see Virtualization.