поиск по всему сайту, а не по группе товаров - PullRequest
0 голосов
/ 23 сентября 2019

У меня есть контроллер поиска, который получает 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);
                }
            }
        }

    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...