前文索引:
ASP.NET Core教程【二】从保存数据看Razor Page的特有属性与服务端验证
ASP.NET Core教程【一】关于Razor Page的知识

实体字段属性

再来看看我们的实体类
    public class Movie
{
public int ID { get; set; }
public string Title { get; set; }

[Display(Name = "Release Date")]
[DataType(DataType.Date)]
public DateTime ReleaseDate { get; set; }
public string Genre { get; set; }
public decimal Price { get; set; }
}
说明,上面的代码需要引用:using System.ComponentModel.DataAnnotations;
Display属性标志这个字段在页面上显示的时候,需要显示什么名字;
我们在上一篇文章中用到的:
<label asp-for="Movie.Title" class="control-label"></label>
这里就会显示Display属性指定的名字;
DataType属性标志这个字段是什么类型的;
上一章中我们说到的,数据类型的验证工作,就是依据这里标志的数据类型来完成的
比如你可以增加如下数据约束
[StringLength(60, MinimumLength = 3)]
[Required] [Range(1, 100)] [RegularExpression(@"^[A-Z]+[a-zA-Z''-'\s]*$")] [DataType(DataType.Currency)]
如果你想格式化输出的内容,你可以使用如下的属性注释
[DisplayFormat(DataFormatString = "{0:yyyy-MM-dd}"]
你可以在同一行代码中标记多个属性,如下:
[RegularExpression(@"^[A-Z]+[a-zA-Z''-'\s]*$"), Required, StringLength(30)]
更多说明文档,可以查阅:https://docs.microsoft.com/zh-cn/aspnet/mvc/overview/older-versions/mvc-music-store/mvc-music-store-part-6

链接标签

在上一篇文章中我们简单说了一下链接标签,再来看第一章中提到的这个场景:
<a asp-page="./Edit" asp-route-id="@item.ID">Edit</a> 
<a asp-page="./Details" asp-route-id="@item.ID">Details</a>
<a asp-page="./Delete" asp-route-id="@item.ID">Delete</a>
asp-page和asp-route-id两个属性共同决定了最终编译出来的链接地址;
以前我们可能要拼字符串来构造href属性,现在不用了,可以分开写,代码更优雅;
上面的代码,编译后生成的href属性的值是这样的:
http://localhost:5000/Movies/Details?id=2
现在我们分别打开Edit.cshtml、Details.cshtml、Delete.cshtml
把页面中的第一个命令:@page,修改为:@page “{id:int}”
重新编译运行,发现上面的链接变成了:
http://localhost:5000/Movies/Details/1
看到这里你会说“呦~”吗?
版权声明:本文为liulun原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:http://www.cnblogs.com/liulun/p/7904602.html