asp怎么循环增加字段和字段对应的值_ASP.NET Core教程「三」实体字段属性

实体字段属性

再来看看我们的实体类

13c58d89776c0f92a545f01a18fb7b58.png

说明,上面的代码需要引用:using System.ComponentModel.DataAnnotations;

Display属性标志这个字段在页面上显示的时候,需要显示什么名字;

我们在上一篇文章中用到的:

3b11013ab05caba267e4cfed12fc739d.png

这里就会显示Display属性指定的名字;

DataType属性标志这个字段是什么类型的;

上一章中我们说到的,数据类型的验证工作,就是依据这里标志的数据类型来完成的

比如你可以增加如下数据约束

0d0485a580e3de3885dc1459edce75e8.png

如果你想格式化输出的内容,你可以使用如下的属性注释

8fb1f349ab95b84f2ecb323a2ed358a5.png

你可以在同一行代码中标记多个属性,如下:

9e2df1b9b9fb184f5af0d0b08e7ef1d6.png

更多说明文档,可以查阅:https://docs.microsoft.com/zh-cn/aspnet/mvc/overview/older-versions/mvc-music-store/mvc-music-store-part-6

链接标签

在上一篇文章中我们简单说了一下链接标签,再来看第一章中提到的这个场景:

7f6695681a562b7a1979f62444ad1a04.png

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

看到这里你会说“呦~”吗?

如果这个时候你请求这个地址:

http://localhost:5000/Movies/Details

并没有传入ID的值,那么服务器会返回404,

如果你的设计是希望ID是一个可选的传入参数,那么你可以把page指令修改成:

2141e0b0ac632c2e4f078077829da956.png

这样就好啦!

如果你想让页面接收一个字符串,可以把这个“路由模版”写成如下这个样子:

1472bb8a56a8f21a039821326b6bbb0c.png

并发数据异常

当一个用户删除了一个实体,另一个用户同时又要更新这个实体的话

第二个用户的请求就会抛出并发数据异常(这里姑且称作并发,微软官网就是这么说的),来看代码:

13da3975c8cae2fff11948e5e530c227.png

上面代码中DbUpdateConcurrencyException就是专门针对这种异常定义的异常类;

NotFound方法将返回404异常

文件上传及读取

如果你想上传一个文件,可以撰写如下razor page的代码(只提供一部分表单域)

76bf3036376d3343cc51cc8f00c7ca7c.png

这个表单域对应的实体如下

acac6a5e7a6de835fc4a70afce155e0e.png

我们只要关注第二个字段即可,UploadPublicSchedule是一个IFormFile类型的字段;

当表单提交后,ASP.NET CORE 也会把文件流绑定到这个字段上;

如果上传的是一个文本文件,那么我们看看怎么直接读取这个文本文件;

fbb9682f8155a475f02e46b4ce57e763.png
06cd9892611c1cbfee01ac96b125c7ff.png

调用上面方法的代码如下:

1544f0df011297be8080f417a872341c.png

其中ModelState是PageModel特有的属性

在本示例中,用于给页面添加错误信息~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值