我正在研究 ASP.NE MVC4,并且正在使用 LungoJS 库进行开发。
我正在开发一个 Helper 以我需要的方式呈现 LungoJS 控件。
对于 Select 输入,我想获得一个 JSON,其中包含每个选项的数据。
我可以从现有控制器的操作中获取所需的 JSON。
但是当我从助手调用操作时,视图会在<pre>
标签内呈现我的 html :-(
看法
<div class="form" id="address-data">
@Html.LungoInputFor(m => m.CaseServiceCaseModel.CaseAddressModel.AddressDataModel.TerritoryId, "text", @Labels.Territory, @htmlAttributesRO, true)
@Html.LungoSelectFor(m => m.CaseServiceCaseModel.CaseAddressModel.AddressDataModel.TerritoryId, @Labels.Territory, null, true, "GetTerritoryKendo", "Address")
帮手
public static MvcHtmlString LungoSelectFor<TModel, TValue>(this HtmlHelper<TModel> html, Expression<Func<TModel, TValue>> expression, string label = "", object htmlAttributes = null, bool fieldset = false, string action = "", string controller = "")
{
TagBuilder tag = new TagBuilder("select");
JavaScriptSerializer js = new JavaScriptSerializer();
MvcHtmlString data = ChildActionExtensions.Action(html, action, controller);
object[] json = js.Deserialize<object[]>(data.ToString());
foreach (Dictionary<string,object> item in json)
{
foreach (var property in item)
{
TagBuilder option = new TagBuilder("option");
switch (property.Key)
{
case "Selected":
if ((bool)property.Value)
{
option.MergeAttribute("selected","selected");
}
break;
case "Text":
option.InnerHtml = property.Value.ToString();
break;
case "Value":
option.MergeAttribute("value", property.Value.ToString());
break;
default:
break;
}
tag.InnerHtml += option.ToString(TagRenderMode.Normal);
}
}
return MvcHtmlString.Create(tag.ToString(TagRenderMode.Normal));
}
我不明白为什么如果我从变量中的 Action 获取 htmlstring,并且在我只返回 Select 输入 html 之后,会影响整个页面......如果我评论ChildActionExtensions.Action(html, action, controller)
视图呈现良好(但没有我的内容需要...)