1

我一直在尝试在此处的答案中实现代码

问题是: -

  1. 设置或创建助手
  2. 将助手集成到视图上以执行 CascadingDropDropListFor

一开始,我尝试为帮助程序创建一个新类,然后我将代码移到了我现有的页面模型中,但发现如果我这样做了,它解决了问题 2,只是说我不能将公共静态类嵌套到我的公共中学生视图模型类。

为了解决问题 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' 之间的模糊引用

您可以在下面看到建议的帮助代码,但我认为我必须在某个阶段做错了,以不断导致这些不同的错误弹出。

            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 中实现级联下拉列表的更简单的方法,我会尝试一下,但我已经在查看一堆其他搜索结果,这是我认为最容易找到的结果实施。

无论如何,任何帮助将不胜感激。

4

2 回答 2

2

使用来自http://awesome.codeplex.com的 AjaxDropdown ,您将不再需要编写 javascript

于 2012-03-07T20:16:49.953 回答
1

采用

System.Web.Mvc.Html.SelectExtensions.DropDownListFor(..);

代替

using System.Web.WebPages.Html;
于 2013-02-08T13:04:18.227 回答