我已经问过这个问题,我没有得到我的答案。所以我对此做了更多的研究,但仍然找不到合适的好答案。
我的控制器(缩短):
public ActionResult SearchResult(String sortOrder, String carMake, String carModel)
{
var cars = from d in db.Cars
select d;
if (!String.IsNullOrEmpty(carMake))
{
if (!carMake.Equals("All Makes"))
{
cars = cars.Where(x => x.Make == carMake);
}
}
if (!String.IsNullOrEmpty(carModel))
{
if (!carModel.Equals("All Models"))
{
cars = cars.Where(x => x.Model == carModel);
}
}
switch (sortOrder)
{
case "Model":
cars = cars.OrderBy(s => s.Model);
break;
default:
cars = cars.OrderBy(s => s.Make);
break;
}
return View(cars);
}
我的索引视图(缩短 - 这是用户通过不同输入过滤汽车的地方):
@model IEnumerable<Cars.Models.Car>
@using (Html.BeginForm("SearchResult", "Home", FormMethod.Post))
{
<label>Make</label>
<select id="MakeID" name="carMake">
<option>All Makes</option>
</select>
<label>Model</label>
<select id="ModelID" name="carModel">
<option>All Models</option>
</select>
<button type="submit" name="submit" value="search" id="SubmitID">Search</button>
}
我的 SearchResult 视图显示搜索结果(缩短):
@model IEnumerable<Cars.Models.Car>
<table>
@foreach (var item in Model)
{
<tr>
<td>
<label>Make:</label>
<p>@Html.DisplayFor(modelItem => item.Make)</p>
</td>
<td>
<label>Model:</label>
<p>@Html.DisplayFor(modelItem => item.Model)</p>
</td>
</tr>
}
</table>
<a href="@Url.Action("SearchResult", "Home", new { sortOrder= "Model"})">Model</a>
我的目标:当用户点击按模型排序时,页面将按模型对结果进行排序。
问题:当点击 sortby 时,
SearchResult
由于 SearchResult 视图中不存在搜索值,所以 action 的所有参数都将为空。问题:如何解决这个问题?
谢谢,阿明
更新:任何例子都将不胜感激。我被后端卡住了在控制器和视图之间发送和获取数据的整个过程。