ASP.NET CORE学习总结
一.什么是asp.net core
简单说:就是一个框架,和java中的Spring差不多
专业点:ASP.NET Core 是一个由微软创建的,用于构建 web 应用、API、微服务 的 web 框架。需要的运行环境为.net
啥是.net?====>>>就是和java中的虚拟机差不多,提供运行的环境
举个例子:鱼必须在水里才能游起来;asp.net core相当于鱼,.net环境就相当于水
优点:速度快 (记住这就行了),更安全(微软爸爸的就是香)
二.asp.net core的项目组成结构介绍
在一个MVC的模板目录中的最重要几个结构:
- Program.cs 和 Startup.cs 文件:设置 web 服务器和 ASP.NET Core 的处理管线。在 Startup 类里,你可以添加中间件,它们用于处理和调整传入的请求、提供静态内容和错误页面。在这里,你还可以向依赖注入容器中添加你自己的服务。
- Models、ViewsModel:处理数据(给视图)views:呈现视图,(给用户看)
- wwwroot 目录里放着 CSS、JavaScript、图片文件 这些静态资源。wwwroot 里的文件将作为静态内容,自动被打包和压缩。
- appsettings.json 文件里包含着 ASP.NET Core 启动时读取的配置信息。可以用它来保存数据库连接字符串,或者其它你不想硬编码的任何内容。
注意:编码软件大部分人喜欢用的是VS,但本人对Rider的真香无法自拔
rider:
在关联git和gitee等远程托管仓库上真的便捷
在各种的快捷键的操作上,就是感觉爽!!!
如果你啥也不会,建议先用vs,弄清基本原理再转rider
三.C#中的mvc模型定义命名
1.Controller层
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
//创建一个AutoController的控制器,注意这是C#语法与java的异同点
namespace AspNetCoreZF.Controllers
{
public class AutoController : Controller
{
// 在这里添加 Actions
}
}
action:
控制器本身处理的路由
简单说:就是处理命令转发到model层(让前端做视图渲染的准备)
作用(专业点):可以返回视图、JSON数据,或者 200 OK和404 Not Found 之类的状态码。返回类型 IActionResult 给了你足够的灵活性.
2.模型层
两个独立的模型层:
第一种:Entity:记录----用来表示在数据库中保存的条目
//如果用过java的Spring应该很好理解,对应数据库表属性关系
using System;
namespace AspNetCoreZF.Models
{
public class AutoItem
{
//定义一个ID
public Guid Id { get; set; }
//事件是否完成
public bool IsDone { get; set; }
//一个标题
[Required]
public string Title { get; set; }
//截止日期
// ? 这玩意代表:此属性可以为空,是可选的,你不写他也不会报错
//若不加此问号,如上面的必须赋值,否则报错
public DateTimeOffset? DueAt { get; set; }
}
}注意:代表是否可空,nullable
有的小伙伴或许与这样的疑问:
C#中的String函数,我不赋值,也没事啊!!
-->>看官方解释:
C#里的字符串总是可空的,所以没必要给 Title 属性添加可空标记。C# 字符串可以没有值,也可以是空白字符串或者包含任意文本。
第二种:Model:视图模型,进行视图渲染的
跟javaweb中的javascript功能差不多(但这里面你会惊讶的发现----wc,相似个锤锤呀!!!)
//视图模型是一个独立的类,里面包含着一个AutoItem(上面的)的数组:
//对应的目录:Models/AutoViewModel.cs
namespace AspNetCoreZF.Models
{
public class AutoViewModel
{
public AutoItem[] Items { get; set; }
}
}
3.创建视图
前提必读:
说明:
ASP.NET Core 里的视图使用 Razor 模板语言编写,这种模板语言混合了 HTML 和 C# 的代码。
Razor:相当于在 Java 下用 Thymeleaf引擎 写的页面
由 AutoController 中的 action Index生成的视图,需要从视图模型(一个待办事项的数组)获取数据,并用一个适当的表格展示给用户。按规定,视图要置于 Views 目录里,在一个与所属控制器同名的子目录下。视图文件的文件名就是 action 的名字加上一个 .cshtml 扩展名。
Views/Todo/Index.cshtml
@:
以符号 @ 作为前缀,掺杂一点 C# 语句,
用以从视图模型里抽取数据并转换为文本或者 HTML。这些 C# 语句。
@model AutoViewModel
@{
ViewData["Title"] = "恭喜你,你已经成功的迈出到另个高度!!";
}
<div class="panel panel-default todo-panel">
<div class="panel-heading">@ViewData["Title"]</div>
<table class="table table-hover">
<thead>
<tr>
<td>?</td>
<td>Item</td>
<td>Due</td>
</tr>
</thead>
@foreach (var item in Model.Items)
{
<tr>
<td>
<input type="checkbox" class="done-checkbox">
</td>
<td>@item.Title</td>
<td>@item.DueAt</td>
</tr>
}
</table>
<div class="panel-footer add-item-form">
<!-- TODO: Add item form -->
</div>
</div>
说明:
在文件顶端,
@model指令告诉 Razor 该视图要绑定到哪个模型。
//作用:
/**
模型通过 `Model` 属性进行访问。
若在 `Model.Items` 里有一些待办事项条目,则foreach语句将遍历到每个代办事项,
并渲染成一个表格的行(`<tr>` 元素),改行包含条目的名字和截止日期。
还会展示一个带有 ID 的复选框,可以在后续操作中把该条目标记为已完成。
*/布局文件:
存放 页首 和 页脚
ASP.NET Core 会使用一个布局视图,用以定义容纳视图的基础结构的其余部分。
布局视图被保存在 Views/Shared/_Layout.cshtml。
4.定制样式表
在wwwroot/css/site.css的目录下写文件即可,当中的site.css可以自己定义名称
Example:
div.todo-panel {
margin-top: 15px;
}
table tr.done {
text-decoration: line-through;
color: #888;
}
四.Add Service类
1.理解service----工欲善其事必先利其器!
这个类干啥子的?
简单说:将数据库的数据以怎样的方式交给controller层后传递给视图显示
(还是懵逼?):
service到底是个啥? 就是店小二
举个例子:
非洲生产的咖啡豆,怎么到上海南京路的高档咖啡厅顾客的杯中?
这个中间的加工,运输以及各种过程的就是相当于service层所要操作的事情,
将咖啡豆进行加工打磨操作相当于我们这里的数据处理
到这里相信大家已经明白了:
具体作用:
渲染视图 并处理接收的数据:你的控制器已经处理好了。
执行业务逻辑,或者说跟你程序的目标和“业务”相关联的代码与逻辑。在一个待办事项列表程序里,业务逻辑意味着“为新任务设置一个默认的截止时间”,或者“仅显示未完成的任务”这些决策。业务逻辑的其它例子,包括“基于产品价格和税率计算总价”,或者“在游戏里检查一个玩家是否有足够的经验值升级”。
存入和取出数据库中的数据。
2.创建接口
C#接口定义规范:
- 接口:一个对象中方法和属性的定义与实际包含这些方法和属性的类分离开来。
- 解耦类(独立性更强),有助测试
- 命名规范:接口以大写字母“I”开头
eg创建文件:Services/IAutoItemService.cs
using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using AspNetCoreTodo.Models;
namespace AspNetCoreZF.Services
{
public interface IAutoItemService
{
//方法签名(method signature)
//表示的意义:“一个 Task 里面装着一个 TodoItem 的数组”
Task<AutoItem[]> GetIncompleteItemsAsync();
}
}
注意:命名空间是一种组织 .NET 代码文件的方式,一般与存放该文件的目录名保持一致,也方便后续维护查看
Task 类型类似于一个 future 或者 promise1,这里使用它的原因是,这将是个 异步的(asynchronous) 方法。换句话说,这个方法可能不会即时返回待办事项的列表,因为它需要先查询数据库。
3.创建服务类
using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using AspNetCoreTodo.Models;
namespace AspNetCoreTodo.Services
{
public class FakeAutoItemService : IAutoItemService
{
public Task<AutoItem[]> GetIncompleteItemsAsync()
{
var item1 = new AutoItem
{
Title = "学习C#来和asp交朋友",
DueAt = DateTimeOffset.Now.AddDays(1)
};
var item1 = new AutoItem
{
Title = "愿拨云见雾之时,已然苍龙出长空!",
DueAt = DateTimeOffset.Now.AddDays(1)
};
return Task.FromResult(new[] { item1, item2 });
}
}
}
后面继续更新,敬请期待
本文参考Microsoft官方文件地址,一切解释和说明均以官方文档为准,以及博客老张的哲学的文章参考