###前提・実現したいこと
検索画面でユーザが入力したチェックボックスやテキストボックスの条件に従って、データベースからデータを抽出し絞り込んで表示する機能を作ろうとしています。
(条件を複雑に定義する前にデータベースのユーザ名項目で検索できる機能を作成しています)
実装としては、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
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。