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

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

ただいまの
回答率

90.00%

ASP.NET WebアプリケーションのViewとControllerの関係を知りたいです。

受付中

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,974

cancat

score 247

こんにちは。 
Windows10でASP.NETのアプリケーションを開発しています。 
Visual Studio 2017 Communityを使っています。 

前提・実現したいこと

ASP.NET Webアプリケーション(.NET Framework)のViewとControllerの関係について疑問があります。
Create.cshtmlを開いたときはControllerのCreate(),、
Create.cshtmlでcreateを押したときは、ControllerのCreate([Bind(Include = "Id,Name,email")] Person person)
が、動きます。

Q1)ASP.NETでないFormやWPFのC#の場合、同じ名前のMethodがふたつある場合、引数をつけて実行するMethodを選択できます。
Create();と実行すればCreate()を、
Create(person)と実行すればCreate(person)を実行します。
とすると、
createボタンでCreate([Bind(Include = "Id,Name,email")] Person person)を実行するということは、createボタンを押したときは、自動的にpersonを引数に取るのでしょうか?

Q2)そうだとすると、この引数のpersonはどこで定義しているのでしょうか?
Create.cshtmlの1行目の
@model ConnectionList.Models.Person
のmodelがそうでしょうか?

Q3)なぜその定義した引数が、
<input type="submit" value="Create" class="btn btn-default" />
だけでついていくの?

Q4)もしボタンが複数あって
<input type="submit" value="Create" class="btn btn-default" />
<input type="button" value="Cancel" class="btn" />//これでOK?
Cancelメソッドがあるとしたら、そこにもpersonはついていくの?

Q5)とすると
<input type="submit" value="Create" class="btn btn-default" />
<input type="button" value="Cancel" class="btn" />//これでOK?
に対応するControllerは、
public ActionResult Cancel()
{
}
ではなくて、
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Cancel([Bind(Include = "Id,Name,email")] Person person)
{
}
でないとだめ?

Q6)するとcshtmlの冒頭では、変数を定義できる、ということ?

Q7)その変数は、cshtmlごとにひとつに限定? それとも複数定義できるの?

Q8)複数定義したときは、Createで受ける引数はふたつになる?

と次々と疑問が噴出してまいりました。
ご助言お願いします。

試したこと

新規プロジェクトで、ASP.NET Webアプリケーション(.NET Framework)を選択。
ASP.NET4.5.2テンプレートはMVCを選択。
認証は個別のユーザーアカウントを選択。

ModelフォルダにPersonクラスを作成。

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

該当のソースコード

namespace ConnectionList.Models
{
    public class Person
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string email { get; set; }
    }
}

Controllersフォルダを選択して、追加-新規スキャフォールディングアイテムを選択。
MVC-コントローラ-Entity Frameworkを使用した、ビューがあるMVC5コントローラーを選択。
モデルクラスにPerson(ConnectionList.Models)、データコンテキストクラスにApplicationDbContext(ConnectionList.Models)を選択して追加。

これで、CURDができました。

PeopleController.csのうちCreateの部分は下記のとおりです。

namespace ConnectionList.Controllers
{
    public class PeopleController : Controller
    {
        // GET: People/Create
        public ActionResult Create()
        {
            return View();
        }

        // POST: People/Create
        [HttpPost]
        [ValidateAntiForgeryToken]
        public ActionResult Create([Bind(Include = "Id,Name,email")] Person person)
        {
            if (ModelState.IsValid)
            {
                db.People.Add(person);
                db.SaveChanges();
                return RedirectToAction("Index");
            }

            return View(person);
        }

    }
}

Create.cshtmlの抜粋は下記のとおりです。

@model ConnectionList.Models.Person

@{
    ViewBag.Title = "Create";
}

<h2>Create</h2>

@using (Html.BeginForm()) 
{
    @Html.AntiForgeryToken()

    <div class="form-horizontal">
        <h4>Person</h4>
        <hr />
        @Html.ValidationSummary(true, "", new { @class = "text-danger" })
        <div class="form-group">
            @Html.LabelFor(model => model.Name, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.EditorFor(model => model.Name, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.Name, "", new { @class = "text-danger" })
            </div>
        </div>

        <div class="form-group">
            @Html.LabelFor(model => model.email, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.EditorFor(model => model.email, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.email, "", new { @class = "text-danger" })
            </div>
        </div>

        <div class="form-group">
            <div class="col-md-offset-2 col-md-10">
                <input type="submit" value="Create" class="btn btn-default" />
            </div>
        </div>
    </div>
}

補足情報(言語/FW/ツール等のバージョンなど)

Microsoft Visual Studio Community 2017
Version 15.0.26228.9 D15RTWSVC
Microsoft .NET Framework
Version 4.6.01586

です。 
よろしくお願いします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

+2

ルーティングとかポストとかパラメータとかの話ですかね。
MVCの基本的な話なので長々と書くよりは色んなサイトとか見てもらった方が早いと思います。

連載:ASP.NET MVC入門

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/05/17 11:30

    それは充分読みました。

    キャンセル

  • 2017/05/17 11:51 編集

    大体答えが書いてあるような気もしますが。
    例えば
    <form action="/Hello/Post/" method="post">
    としたらHelloコントローラのPostアクションメソッドが呼ばれる、と記事には説明されているので、Q5のような質問は出ないですよね?

    <input type="button" value="Cancel" class="btn" />//これでOK?
    というのもただの何も動作しないボタンでしかないですよね?
    どの遷移先(どのコントローラのどのアクション)に飛ぶのか書いていないので動作しません。(これはHTMLレベルの話かな?)

    キャンセル

0

View Controller Modelの概念が必要です。
ViewとControllerの関係性ですが、
ControllerがModelの振り分けを行う司令塔で、
ViewはControllerで指定されたModelを表示するテレビです。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/05/17 11:30

    それはわかっているつもりなので、具体例を。

    キャンセル

  • 2017/05/17 17:04

    Q1)Bindあんま使わないから分からない。すいません。
    Q2)持ってるパラメータはご指摘の通り一行目で宣言しているモデルの中身のプロパティです。
    Q3)submitはformを送信する処理になります。Html.beginfrom内で宣言されているパラメータを全て投げます。
    Q4)submitでないと付いてこないと思いますが間違ってたらすいません。
    Q5)bindよく分からない・・・
    Q6)行頭で宣言している@model うんたらは変数の定義してるModelを読み込んでます。
    ごちゃごちゃになってるようなのでModelを勉強してください。
    Q7)複数は出来ませんが、継承等はできます。
    Q8)

    キャンセル

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

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