質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.33%

MVCでViewからControllerへのDatatableの受け渡しについて

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 9,724

Yuki_S

score 356

前提・実現したいこと

MVCでアプリケーションを作成した際に自動生成されるAccountに対して、role(役割)を付加して[Authorize(Roles = "Admin,Editor")]などが使える状態にしています。
管理者権限を持っているユーザーが他のユーザーに権限を割り当てるページを作成したいのですが、各ユーザーごとに編集ページに遷移するのはユーザーの数が増えると非常に使い勝手が悪くなると思い、今回は一括で編集できるようなページを作成しようとしています。(下図イメージ)

イメージ説明

この登録のボタンを押した際にデータがサーバーに反映されて、ページが更新される仕様にしたいを実装したいです。

発生している問題・エラーメッセージ

データベースの各テーブルから必要なデータを取得して、各ユーザーの社員番号とどの権限を持っているかをテーブルに表記することはできましたが、登録ボタン押下時にControllerへテーブルにした情報をDataTableなどにして返す方法がわかりませんでした。

該当のソースコード

Controller

public ActionResult Index(DataTable strmodel)
        { 
       テーブルに情報があれば内容を精査してデータベースに書き込みを行う。

            DataTable tb = new DataTable();
            var Manager = new RoleManager<ApplicationRole>(new RoleStore<ApplicationRole>(new ApplicationDbContext()));
            var models = new UserManager<ApplicationUser>(new UserStore<ApplicationUser>(new ApplicationDbContext()));

                System.Type TpStr = typeof(string);
                System.Type Tpbool = typeof(bool);               

                tb.Columns.Add(new DataColumn("社員番号", TpStr));

                foreach (ApplicationRole role in Manager.Roles)
                {
                    tb.Columns.Add(new DataColumn(role.Name, Tpbool));
                }

                var dr = tb.NewRow();

                foreach (var model in models.Users)
                {             
                    dr["社員番号"] = model.UsId;

                    foreach (ApplicationRole role in Manager.Roles)
                    {
                        var Usrole = role.Users.Select(a => a.UserId).ToList();

                        if (Usrole.Contains(model.Id.ToString()))
                        {
                            dr[role.Name] = true;
                        }
                        else
                        {
                            dr[role.Name] = false;
                        }
                    }
                    tb.Rows.Add(dr);
                }
            return View(tb);
        }
    }

view

@using (Html.BeginForm("Index", "Account", FormMethod.Get, new { @class = "form-inline" }))
{

    <table class="table">
        <tr>
            @foreach (var item in Model.Columns)
            {
                <th>
                    @item.Caption
                </th>
            }
        </tr>

        @foreach (System.Data.DataRow item in Model.Rows)
        { 
            <tr>
                @{
                    count = item.ItemArray.Count();
                }
                @for (var i = 0; i < count; i++)
                {
                    <td>
                        @if (item.ItemArray[i].GetType() == typeof(string))
                        {
                            @item.ItemArray[i]
                        }
                        else
                        {
                            @Html.CheckBox((string)Model.Columns[i].Caption, (bool)item.ItemArray[i])
                        }
                    </td>
                }
         </tr>
                    }
    </table>

    <div class="form-group">
            <input type="submit" class="btn btn-default" value="登録" />
    </div>
}

試したこと

View側の情報をViewbagに格納してみたりしましたが、チェックボックスの編集後の情報が入ってこないなどの状況です。

せつめいな

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

こんにちわ、ボタンクリック後、Controllerに処理が渡るけど、Modelに入っていないということでしょうか。可能であればModelも載せていただけるとありがたいです。
以下、tableタグ内にチェックボックスを配置し、ボタンクリックでControllerに渡っています。(VisualStudioのデフォルトのアプリケーションに少し手を加えただけなので見難くて申し訳ありません)
View

@using (Html.BeginForm("Register", "Account", FormMethod.Post, new { @class = "form-horizontal", role = "form" }))
{

    @Html.AntiForgeryToken()
    @Html.ValidationSummary("", new { @class = "text-danger" })

    <table class="table">
        <tr>
            <td>
                <div class="form-group">
                    <div class="col-md-10">
                        @Html.CheckBoxFor(m => m.IsCheck, new { @class = "form-control" })
                    </div>
                </div>
            </td>
        </tr>
    </table>
    <div class="form-group">
        <div class="col-md-offset-2 col-md-10">
            <input type="submit" class="btn btn-default" value="登録" />
        </div>
    </div>
}


Model

[Required]
[Display(Name = "Check")]
public bool IsCheck { get; set; }


Controller

public async Task<ActionResult> Register(RegisterViewModel model)
{
・
・
・


ASP.NET MVCのモデルバインド周りは、はまったら悩ましいですよね。参考になれば幸いです。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/05/23 17:07

    ご回答ありがとうございました。
    まずはしようもないところで、FormMethod.PostをGetにしていました。

    ModelはAccountのものをほぼそのまま使っており、変更を特に加えていません。
    その為、サーバーのテーブルを見るとUserのテーブルとUserRoleのテーブルの二つに分かれていました。よって、チェックボックスを受け渡すためにクラスを作成して、テーブル内のデータを受け取り、各チェックボックスの結果をもとに

    UserManager.AddToRoles();

    のメソッドを使って役割の編集ができるようになりました。
    ありがとうございました。


    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.33%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る