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

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

新規登録して質問してみよう
ただいま回答率
85.50%
ASP.NET MVC Framework

ASP.NET MVC Frameworkは、MVCパターンをベースとした、マイクロソフトのウェブアプリケーション開発用のフレームワークです。

Q&A

1回答

6279閲覧

ASP.NETCoreのViewComponentによる検索画面の実装

Spira_n43

総合スコア8

ASP.NET MVC Framework

ASP.NET MVC Frameworkは、MVCパターンをベースとした、マイクロソフトのウェブアプリケーション開発用のフレームワークです。

0グッド

0クリップ

投稿2016/06/11 14:02

###前提・実現したいこと
検索画面でユーザが入力したチェックボックスやテキストボックスの条件に従って、データベースからデータを抽出し絞り込んで表示する機能を作ろうとしています。
(条件を複雑に定義する前にデータベースのユーザ名項目で検索できる機能を作成しています)

実装としては、ASP.NET Core MVC のviewComponentの機能を利用して、ビューにベースレイアウトや検索条件(チェックボックスやテキストボックス)、viewComponentのビューにデータベースから取得したデータを表示する構成で考えました。

###発生している問題・エラーメッセージ
該当ソースコードの通り実装したところ、検索条件のとおり検索結果は表示されるのですがviewComponentで定義したviewの部分だけで、検索条件などを表示している元のビューが表示されません(部分ビューのみ表示される)

**検索条件をpostした際に、元のビューはそのままで、viewComponentで定義したviewのみ更新して表示させたいです。
**

###該当のソースコード
ASP.NET Core 1.0(RC2) MVC (C#)

//ビューのコード(抜粋)

<form asp-action="Search" asp-controller="Member" method="Post" enctype="multipart/form-data" role="form" asp-anti-forgery="true"> <input asp-for="UserName" type="text" class="form-control" id="UserName" placeholder="ユーザー名"> <button type="submit" class="btn btn-signup">検索</button> </form> @await Component.InvokeAsync("MemberList")

//controller(MemberController)の処理
[HttpGet]
public IActionResult Search()
{
return View();
}

[HttpPost]
[ValidateAntiForgeryToken]
public IActionResult Search(string UserName)
{
return ViewComponent("MemberList", new { UserName = UserName });
}

// viewComponentの処理
public MemberListViewComponent(ApplicationDbContext context)
{
_context = context;
}
public IViewComponentResult Invoke(string UserName)
{
//デフォルト全件
var items = from a in _context.*****(モデル名)
select a;

//ユーザ名が空で無い場合、部分一致検索 if (!string.IsNullOrEmpty(UserName)) { items = items.Where(a => a.UserName.Contains(UserName)); } return View(items); }

//viewComponentのビュー
@model IEnumerable<モデル名>
@foreach (var member in Model)
{
省略(表示する項目名を列挙しています)
}

###補足情報(言語/FW/ツール等のバージョンなど)
ASP.NET Core 1.0(RC2) MVC

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ASP.NET Coreをしっかりとキャッチアップできているわけではないのですが
ViewComponentは、私の理解ではPartial Viewの扱いに近いものと理解しています。

https://docs.asp.net/en/latest/mvc/views/view-components.html
http://blog.shibayan.jp/entry/20141123/1416746894

ですので、検索項目と検索結果で、検索結果の表示だけを部分的に変更したいということであれば
AjaxでViewComponentを返すAPIをたたき、その結果のDOMを検索結果部分に流しこむような事が必要になるのではないかと思います。

該当のソースコードのSearchをPOSTした結果はあくまでも、
ViewComponentを叩いた結果(部分的なView)を返しており、
それをreturnしていますので結果としてViewComponentの部分のみが画面に表示されているのだと思います。

間違っている部分がありましたら、申し訳ないですが問題解決のお役にたてればと思います

投稿2016/06/13 05:14

shika358

総合スコア122

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問