У меня есть контроллер поиска, который получает Searchid и keywordSearch для отображения результатов поиска.например, пользователь может искать iPhone в мобильной категории.Я пытаюсь сделать поиск по любому ключевому слову (KeywordSearch) во всех группах продуктов (Searchid), и мне нужна помощь в этом.
HTML-код:
<div class="top_search_form">
@using (Html.BeginForm("Search", "Home", FormMethod.Get, new { @class = "search_form clearfix", @id = "frm_topsearch" }))
{
<div id="search_box">
<select name='Searchid' style="margin-left:1px;">
@foreach (var item1 in repsearch.GetGroup())
{
<option value='@item1.Group_ID'>@item1.Group_Name</option>
}
</select>
<input type="text" placeholder="search" name='keywordSearch'>
<input type="submit" class="fa fa-search" style="margin-right: 1px;width:38px !important;background-color: #CC456B !important;height: 34px !important;" name="name" value="search" />
</div>
<div id="search_result_box">
</div><!-- end search_result_box -->
}
Контроллер:
[HttpGet]
public ActionResult Search(int Searchid, string keywordSearch)
{
var qid = db.Tbl_Group.Where(a => a.Group_ID == Searchid).FirstOrDefault();
if (qid == null)
{
return RedirectToAction("Index");
}
else
{
if (keywordSearch == "" || keywordSearch == null)
{
var q = db.Tbl_Product.Where(a => a.Product_Groupid == Searchid).ToList();
if (q == null)
{
ViewBag.State = "Error";
ViewBag.Key = keywordSearch;
ViewBag.Groupid = Searchid;
return View();
}
else
{
ViewBag.State = "Ok";
ViewBag.Key = keywordSearch;
ViewBag.Groupid = Searchid;
return View(q);
}
}
else
{
var search = (from a in db.Tbl_Product where a.Product_Groupid == Searchid && a.Product_Name.Contains(keywordSearch) select a).ToList();
if (search == null)
{
ViewBag.State = "Error";
ViewBag.Key = keywordSearch;
ViewBag.Groupid = Searchid;
return View();
}
else
{
ViewBag.State = "Error";
ViewBag.Key = keywordSearch;
ViewBag.Groupid = Searchid;
return View(search);
}
}
}
}