Я пытался реализовать код в ответе здесь
Проблемы: -
- Настройка или создание помощника
- интеграция помощника в представление для выполнения CascadingDropDropListFor
Сначала я попытался создать новый класс для помощника, затем вместо этого переместил код в свою существующую модель для страницы, но обнаружил, что я сделал это.решил проблему 2, просто чтобы сказать, что я не могу вложить общедоступный статический класс в свой общедоступный класс StudentViewModel.
Чтобы решить проблему 1, я попытался ввести столько «Использования», сколько необходимо, чтобы заставить весь код работать, а затем я обнаружил, что Web.Mvc.Html предназначен для его решения, но этого не произошло, и вызвал другую ошибку.,
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
using System.Web;
using System.Web.Mvc;
using System.Web.Mvc.Html;
Я обнаружил, что
using System.Web.WebPages.Html;
Решена проблема Html .SelectExtension, с которой вы можете увидеть ошибку ниже
Имя «Html» не существует в текущем контексте
Но вызвано
«SelectListItem» является неоднозначной ссылкой между «System.Web.Mvc.SelectListItem» и'System.Web.WebPages.Html.SelectListItem'
Ниже вы можете увидеть предложенный код помощника, но я думаю, что на каком-то этапе я должен что-то делать не так, чтобы постоянно вызывать появление этих различных ошибокup.
public static class MvcHtmlExtensions
{
public static MvcHtmlString CascadingDropDownListFor<TModel, TProperty>(
this HtmlHelper<TModel> htmlHelper,
Expression<Func<TModel, TProperty>> expression,
IEnumerable<SelectListItem> selectList,
string optionLabel,
IDictionary<string, Object> htmlAttributes,
string parentControlName,
string childListUrl
)
{
var memberName = GetMemberInfo(expression).Member.Name;
MvcHtmlString returnHtml = Html.SelectExtensions.DropDownListFor(htmlHelper, expression, selectList, optionLabel, htmlAttributes);
var returnString = MvcHtmlString.Create(returnHtml.ToString() +
@"<script type=""text/javascript"">
$(document).ready(function () {
$(""#<<parentControlName>>"").change(function () {
var postData = { <<parentControlName>>: $(""#<<parentControlName>>"").val() };
$.post('<<childListUrl>>', postData, function (data) {
var options = """";
$.each(data, function (index) {
options += ""<option value='"" + data[index].Id + ""'>"" + data[index].Name + ""</option>"";
});
$(""#<<memberName>>"").html(options);
})
.error(function (jqXHR, textStatus, errorThrown) { alert(jqXHR.responseText); });
});
});
</script>"
.Replace("<<parentControlName>>", parentControlName)
.Replace("<<childListUrl>>", childListUrl)
.Replace("<<memberName>>", memberName));
return returnString;
}
private static MemberExpression GetMemberInfo(Expression method)
{
LambdaExpression lambda = method as LambdaExpression;
if (lambda == null)
throw new ArgumentNullException("method");
MemberExpression memberExpr = null;
if (lambda.Body.NodeType == ExpressionType.Convert)
{
memberExpr = ((UnaryExpression)lambda.Body).Operand as MemberExpression;
}
else if (lambda.Body.NodeType == ExpressionType.MemberAccess)
{
memberExpr = lambda.Body as MemberExpression;
}
if (memberExpr == null)
throw new ArgumentException("method");
return memberExpr;
}
}
}
В противном случае, если кто-нибудь узнает о гораздо более простом способе реализации каскадных выпадающих списков в mvc3, я попробую это вместо этого, но я уже искал кучу других результатов поиска для него.и это был тот, который я решил реализовать проще всего.
В любом случае, любая помощь будет высоко ценится.