@Html.Label()
,@Html.LabelFor()
和@Html.LabelForModel()
方法之间有什么区别?
答案 0 :(得分:106)
Html.Label
为您的名称与指定输入文本匹配的输入提供标签(更具体地说,对于与字符串表达式匹配的模型属性):
// Model
public string Test { get; set; }
// View
@Html.Label("Test")
// Output
<label for="Test">Test</label>
Html.LabelFor
为您提供的表达式(通常是模型属性)所代表的属性提供标签:
// Model
public class MyModel
{
[DisplayName("A property")]
public string Test { get; set; }
}
// View
@model MyModel
@Html.LabelFor(m => m.Test)
// Output
<label for="Test">A property</label>
Html.LabelForModel
有点棘手。它返回一个标签,其for
值是模型对象表示的参数的值。这对于自定义编辑器模板尤其有用。例如:
// Model
public class MyModel
{
[DisplayName("A property")]
public string Test { get; set; }
}
// Main view
@Html.EditorFor(m => m.Test)
// Inside editor template
@Html.LabelForModel()
// Output
<label for="Test">A property</label>
答案 1 :(得分:12)
Html.Label
- 只需创建一个标签标签,其中包含传递给构造函数的字符串
Html.LabelFor
- 为该特定属性创建标签。这是强类型的。默认情况下,这只会执行属性的名称(在下面的示例中,如果Display属性不存在,它将输出MyProperty)。这样做的另一个好处是你可以在你的模型中设置显示属性,这将是放在这里的内容:
public class MyModel
{
[Display(Name="My property title")
public class MyProperty{get;set;}
}
在您看来:
Html.LabelFor(x => x.MyProperty) //Outputs My property title
在上面,LabelFor将显示<label for="MyProperty">My property title</label>
。这非常有效,因此您可以在一个地方定义该属性的标签,并将其显示在任何地方。
答案 2 :(得分:6)
我认为应该更详细地解释using System.ComponentModel;
[DisplayName("MyModel")]
public class MyModel
{
[DisplayName("A property")]
public string Test { get; set; }
}
的用法。
LabelForModel方法返回HTML标签元素以及由模型表示的属性的属性名称。
您可以参考以下代码:
模型中的代码:
@Html.LabelForModel()
<div class="form-group">
@Html.LabelFor(model => model.Test, new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.Test)
@Html.ValidationMessageFor(model => model.Test)
</div>
</div>
视野中的代码:
ColorDrawable
输出屏幕截图:
答案 3 :(得分:3)
假设您需要一个带有文本customername的标签,而不是使用2种方式来实现它
[1]@Html.Label("CustomerName")
[2]@Html.LabelFor(a => a.CustomerName) //strongly typed
第二种方法使用了模型中的属性。如果您的视图实现了模型,那么您可以使用第二种方法。
更多信息,请访问以下链接
http://weblogs.asp.net/scottgu/archive/2010/01/10/asp-net-mvc-2-strongly-typed-html-helpers.aspx