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



我正在用ASP开发一个多语言web应用程序。净MVC。但是有些语言是可选的。例如,用户在屏幕上看到两个文本框。一个是英语的,另一个是法语的。我想通过web.config动态创建文本框。如果"ActiveLanguageList"在web。配置有一个语言代码,因此应用程序为该语言创建一个文本框。但我不能从视图模型动态地创建它。我必须手动编写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
 }

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

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
}

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

在你所有的"ContentName"属性上设置这个属性。

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

示例(不生成html): https://dotnetfiddle.net/RRvC6K

最新更新