我已在我的MVC5视图上实现了kendo组合框,并希望根据模型中的值过滤组合框。我需要从模型中检索值。我目前已将该值绑定到我的局部视图中名为CountryCode的隐藏字段。该脚本在我的主视图中。我试图访问隐藏字段时收到错误消息未定义。该模型肯定会填充CountryCode。
@using System.Collections
@model CC.GRP.MCRequest.ViewModels.RequestStatusUpdateViewModel
@{
Layout = null;
}
<div class="k-popup-edit-form k-window-content k-content" >
<div class="k-edit-form-container">
@Html.HiddenFor(model => model.CountryCode)
<div class="editor-label">
@Html.LabelFor(model => model.RequestID)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.RequestID, new { htmlAttributes = new { @readonly = "readonly" } })
</div>
<div class="editor-label">
@Html.LabelFor(model => model.ProjectName)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.ProjectName, new { htmlAttributes = new { @readonly = "readonly" } })
</div>
<div class="editor-label">
@Html.LabelFor(model => model.RequestStatus)
</div>
<div class="editor-field">
@(Html.Kendo().ComboBoxFor(model => model.RequestStatusCode)
.HtmlAttributes(new { style = "width:100%" })
.DataTextField("Status")
.Placeholder("Select...")
.DataValueField("RequestStatusCode")
.AutoBind(false)
.Filter("contains")
.DataSource(dataSource => dataSource
.Read(read =>
{
read.Action("GetRequestStatus", "Request")
.Type(HttpVerbs.Post)
.Data("GetCountryCodeFilter");
}).ServerFiltering(true)
)
)
</div>
@Html.ValidationMessageFor(model => model.RequestStatusCode, "", new { @class = "text-danger" })
</div>
</div>
填充组合的控制器方法
public ActionResult GetRequestStatus(string countryCode)
{
var response = requestRepository.GetRequestStatus(countryCode).AsQueryable().ProjectTo<RequestStatusViewModel>();
var jsonResult = Json(response, JsonRequestBehavior.AllowGet);
jsonResult.MaxJsonLength = int.MaxValue;
return jsonResult;
}
加载视图的控制器方法
public ActionResult RequestStatus(int requestId, string projectName, string countryCode)
{
RequestStatusUpdateViewModel reqeustStatusUpdateViewModel = new RequestStatusUpdateViewModel();
reqeustStatusUpdateViewModel.RequestID = requestId;
reqeustStatusUpdateViewModel.ProjectName = projectName;
reqeustStatusUpdateViewModel.CountryCode = countryCode;
if (!ModelState.IsValid)
{
// return View("NewRequestView", Mapper.Map<RequestStatusViewModel>(newReqeustViewModel));
return null;
}
return View("_RequestStatusView", Mapper.Map<RequestStatusUpdateViewModel>(reqeustStatusUpdateViewModel));
}
RequestStatusViewModel
public class RequestStatusViewModel
{
public string RequestStatusCode { get; set; }
public string Status { get; set; }
public int DisplaySequenceNo { get; set; }
}
主视图中的脚本
function GetCountryCodeFilter() {
alert("Hello");
alert($('#CountryCode').val());
return { countryCode: $('#CountryCode').val() }
};
答案 0 :(得分:1)
我假设这是一个来自剑道网格的弹出窗口。问题是视图被序列化并在单击任何行时发送到弹出窗口。它没有像你期望的那样在MVC中绑定数据 - 它每次都发送相同的序列化数据。请参阅here。
因此,将隐藏更改为使用kendo的MVVM绑定,以便每个实例从网格行获取值。 (CountryCode需要存在于网格的数据源中):
@Html.HiddenFor(x => x.CountryCode, new { data_bind = "value: CountryCode" }) // underscore becomes dash
或者您可以使用:
<input type="hidden" name="CountryCode" id="CountryCode" data-bind = "value: CountryCode"/>