通过 Web.Config 参数动态生成视图

Dynamically Generate View By Web.Config Parameter

我正在使用 ASP.NET MVC 开发多语言 Web 应用程序。但有些语言是可选的。例如,用户在屏幕上看到两个文本框。其中一个用于英语,另一个用于法语。我想通过 web.config 动态创建文本框。如果 web.config 中的 "ActiveLanguageList" 有语言代码,那么应用程序会为该语言创建一个文本框。但我无法从我的视图模型动态创建它。我必须手动编写 HTML 帮助程序。我想用循环等动态创建它们...因为 HTML 页面中的国家代码是不同的。例如"ContentNameEn"、"ContentNameFr" 感谢您的建议。

//in my setting class
var ActiveLangs = new List<string>(); //For example EN,FR

//in web.config
<add key="Languages" value="EN,FR"/>

//in my view model
[DisplayName("English Content Name")]
public string ContentNameEn { get; set; }

[DisplayName("French Content Name")]
public string ContentNameFr { get; set; }


//in myview
<div class="form-group">
    <label class="control-label col-md-2" for="ContentName">Content Name(EN)</label>
    <div class="col-md-4">
        @Html.TextBoxFor(model => model.ContentNameEn, new { @class = "form-control" })
        @Html.ValidationMessageFor(model => model.ContentNameEn)
    </div>
</div>

<div class="form-group">
    <label class="control-label col-md-2" for="ContentName">Content Name(FR)</label>
    <div class="col-md-4">
        @Html.TextBoxFor(model => model.ContentNameFr, new { @class = "form-control" })
        @Html.ValidationMessageFor(model => model.ContentNameFr)
    </div>
</div>

 //i want to code in the view like this but i can't
 @foreach(var langCode in ActiveLangs){
   //i need here create langCode's html code with htmlhelper
   //@Html.TextBoxFor
   //@Html.LabelFor
 }

您可以创建一个属性,指定 属性 只有在 web.config 中定义时才必须显示。

在您的所有 "ContentName" 属性上设置此属性。

使用反射恢复所有包含此属性的模型属性。对于每个 属性,检查关联代码是否存在于 web.config 中,并生成相应的 html 文本框。

示例(没有 html 代):https://dotnetfiddle.net/RRvC6K

因为要生成的文本框数量未知,所以您的模型需要是一个集合。您的视图模型应该是

public class ContentVM
{
  public string LanguageCode { get; set; }
  public string LanguageName { get; set; } // used for the label
  [Required]
  public string ContentName { get; set; }
}

然后在控制器中,创建一个集合。请注意,您在 Web.Config 中存储代码的方法可能需要更改以允许您也存储语言名称(xml 文件可能是更好的解决方案)。例如

List<ContentVM> model = new List<ContentVM>();
foreach (var language in ...)
{
  model.Add(new ContentVM(){ LanguageCode = language.Code, LanguageName = language.Name };
}
return View(model);

然后您的视图将是

@model List<ContentVM>
....
@using (Html.BeginForm())
{
  for(int i = 0; i < Model.Count; i++)
  {
    @Html.HiddenFor(m => m[i].LanguageCode)
    @Html.LabelFor(m => m[i].ContentName, Model[i].LanguageName)
    @Html.TextBoxFor(m => m[i].ContentName)
    @Html.ValidationMessageFor(m => m[i].ContentName)
  }
  <input type=submit" ... />
}

并在 POST 方法中

public ActionResult Edit(List<ContentVM> model)
{
  // loop through the collection to get each ContentName and the associated LanguageCode
}