ASP.NET Core MVC コントロールヘルプ
現在のレコードの管理
コントロールの使用 > CollectionView > CollectionViewの使用 > クライアント側処理 > 現在のレコードの管理

CollectionViewは、ICollectionViewインタフェースを使用して現在のレコードを管理できます。

コレクションのレコードの現在位置を取得するには、currentPositionプロパティを使用します。また、moveCurrentTo(item)、moveCurrentToFirst()、moveCurrentToLast()、moveCurrentToNext()、moveCurrentToPosition(index)、およびmoveCurrentToPrevious()メソッドを使用して現在位置を変更します。現在位置が変更されると、currentChangingイベントとcurrentChangedイベントを使用して追跡されます。currentChangingイベント内の現在の変更はキャンセルできます。

クライアント側のみで使用できるデータに対してフィルタ処理、ページング、ソートを行う場合は、ItemSourceDisableServerReadプロパティを必ずtrueに設定してください。

この例ではC1NWindデータソースを使用しますが、これは「クイックスタート」で示されているようにアプリケーション内で設定されたものです。

次のコード例は、FlexGridでCollectionViewを介して現在のレコードを管理する方法を示します。

コードの場合

CurrentRecordManagementController.cs

C#
コードのコピー
private C1NWindEntities db = new C1NWindEntities();
public ActionResult Index()

{
    return View(db);
}
public ActionResult GridReadCategory([C1JsonRequest] 
    CollectionViewRequest<Customers> requestData)
{
    return this.C1Json(CollectionViewHelper.Read(requestData, db.Customers));
}
       

CurrentRecordManagement.cshtml

HTML
コードのコピー
<div>
    <button class="btn btn-default" id="btnCRMMoveNext">次へ</button>
    <button class="btn btn-default" id="btnCRMMovePre">前へ</button>
    <button class="btn btn-default" id="btnCRMStop4">4行目で停止</button>
    <button class="btn btn-default" id="btnCRMReset">停止をクリア</button>
</div>

<c1-flex-grid  id="crmGrid" auto-generate-columns="true" selection-mode="Row" height="300" 
      Width="800" IsReadOnly="true">
    <c1-items-source source-collection="@Model" disable-server-read="true"></c1-items-source>
</c1-flex-grid>
スクリプト
コードのコピー
<script>
    $(document).ready(function () {
        //現在レコードを管理します
        crmGrid = wijmo.Control.getControl('#crmGrid');
        cvCRM = crmGrid.itemsSource; //new wijmo.collections.CollectionView(getData(10)),

        // ボタンクリックに対して処理を追加します
        // 次の項目へ移動します
        document.getElementById('btnCRMMoveNext').addEventListener('click', function () {
            cvCRM.moveCurrentToNext();
        });

        // 前の項目へ移動します
        document.getElementById('btnCRMMovePre').addEventListener('click', function () {
            cvCRM.moveCurrentToPrevious();
        });

        // 4番目の項目が現在の項目になる時は、変更を制限します
        document.getElementById('btnCRMStop4').addEventListener('click', function () {
            cvCRM.currentChanging.addHandler(stopCurrentIn4th);
        });

        // 変更できるように復元します
        document.getElementById('btnCRMReset').addEventListener('click', function () {
            cvCRM.currentChanging.removeHandler(stopCurrentIn4th);
        });

        // 現在の移動の動作を停止する関数を定義します
        function stopCurrentIn4th(sender, e) {
            // 4番目の項目現在の項目になる時、移動を停止します
            if (sender.currentPosition === 3) {
                e.cancel = true;
            }
        };
    });

    // コレクションビュー、グリッドを作成します
    var crmGrid = null
        , cvCRM = null;

</script>