FlexGrid
ソート
機能
サンプル
設定
ソートするフィールド : ソート順 :説明
このサンプルでは、最初のリストで選択されたフィールド値に基づいてコレクションをソートすることができます。また、2 番目のリストでソート順を指定することもできます。
ユーザーが一度に1つまたは複数の列をソートできるように、SortingType プロパティを使用してこの動作を変更します。
ユーザーが一度に1つまたは複数の列をソートできるように、SortingType プロパティを使用してこの動作を変更します。
ソース
SortingController.cs
using C1.Web.Mvc; using C1.Web.Mvc.Serialization; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using MvcExplorer.Models; using System.Collections.Generic; namespace MvcExplorer.Controllers { public partial class FlexGridController : Controller { private readonly ControlOptions _sortingDataModel = new ControlOptions { Options = new OptionDictionary { {"Sorting type", new OptionItem {Values = new List<string> {"None", "SingleColumn", "MultiColumn"}, CurrentValue = "SingleColumn"}} } }; public ActionResult Sorting(IFormCollection collection) { _sortingDataModel.LoadPostData(collection); ViewBag.DemoOptions = _sortingDataModel; return View(); } public ActionResult Sorting_Bind([C1JsonRequest] CollectionViewRequest<Sale> requestData) { return this.C1Json(CollectionViewHelper.Read(requestData, Sale.GetData(500))); } } }
Sorting.cshtml
@using C1.Web.Mvc.Grid @model IEnumerable<Sale> @{ var fields = new[] { "ID", "Start", "End", "Country", "Product", "Color", "Amount", "Amount2", "Discount", "Active" }; var orders = new[] { "Ascending", "Descending" }; ControlOptions optionsModel = ViewBag.DemoOptions; ViewBag.DemoSettings = true; ViewBag.SettingsByMenu = false; } <c1-flex-grid id="flexgrid" class="grid" auto-generate-columns="false" is-read-only="true" order-by="ID" sorting-type="@((AllowSorting)Enum.Parse(typeof(AllowSorting), optionsModel.Options["Sorting type"].CurrentValue))"> <c1-flex-grid-column binding="ID"></c1-flex-grid-column> <c1-flex-grid-column binding="Start"></c1-flex-grid-column> <c1-flex-grid-column binding="End"></c1-flex-grid-column> <c1-flex-grid-column binding="Country"></c1-flex-grid-column> <c1-flex-grid-column binding="Product"></c1-flex-grid-column> <c1-flex-grid-column binding="Color"></c1-flex-grid-column> <c1-flex-grid-column binding="Amount" format="c"></c1-flex-grid-column> <c1-flex-grid-column binding="Amount2" format="c"></c1-flex-grid-column> <c1-flex-grid-column binding="Discount" format="p0"></c1-flex-grid-column> <c1-flex-grid-column binding="Active"></c1-flex-grid-column> <c1-items-source read-action-url="@Url.Action("Sorting_Bind")"></c1-items-source> </c1-flex-grid> @section Scripts{ <script> var field = "ID", order = "Ascending"; function sortGrid(combo) { var flexGrid, ascending, sd; if (combo.hostElement.id === "sortingfield") field = combo.selectedValue; if (combo.hostElement.id === "sortingorder") order = combo.selectedValue; if (!field || !order) { return; } flexGrid = wijmo.Control.getControl("#flexgrid"); ascending = order === "Ascending"; sd = flexGrid.collectionView.sortDescriptions; sdNew = new wijmo.collections.SortDescription(field, ascending); // remove any old sort descriptors and add the new one sd.splice(0, sd.length, sdNew); } </script> } @section Settings { @Html.Raw(FlexGridRes.Sorting_SortingField) : <c1-combo-box id="sortingfield" selected-index="0" is-editable="false" selected-index-changed="sortGrid"><c1-items-source source-collection="@fields"></c1-items-source></c1-combo-box> @Html.Raw(FlexGridRes.Sorting_SortingOrder) : <c1-combo-box id="sortingorder" selected-index="0" is-editable="false" selected-index-changed="sortGrid"><c1-items-source source-collection="@orders"></c1-items-source></c1-combo-box> @await Html.PartialAsync("_OptionsMenu", optionsModel) } @section Description{ @Html.Raw(FlexGridRes.Sorting_Text0) <br /> @Html.Raw(FlexGridRes.SortingType_Text0) }
マニュアル