MVC Core 网站开发(Ninesky) 2.1、栏目的前台显示

上次创建了栏目模型,这次主要做栏目的前台显示。涉及到数据存储层、业务逻辑层和Web层。用到了迁移,更新数据库和注入的一些内容。

一、添加数据存储层

1、添加Ninesky.DataLibrary(与上次添加方法相同)

解决方案(Ninesky)上点右键->添加->新建项目

选择.NET Core –> Class Library(.NET Core)

名称输入:Ninesky.DataLibrary(数据访问存储功能在这个项目中实现)

2、为项目添加EntityFrameworkCore包

Ninesky.DataLibrary项目的引用中右键-> 管理NuGet程序包

在对话框中选择浏览标签,搜索框中输入“EntityFrameworkCore”,然后找到”Microsoft.EntityFrameworkCore”点击安装。

点击更新标签,选择NETStandard.Library,点更新,更新到1.6.1版本。

3、实现单个数据查询

将项目中默认生成的Class1.cs,改名为BaseRepository.cs

添加代码如下:

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Linq;
  4 using System.Threading.Tasks;
  5 using Microsoft.EntityFrameworkCore;
  6
  7 namespace Ninesky.DataLibrary
  8 {
  9     /// <summary>
 10     /// 仓储基类
 11     /// </summary>
 12     public class BaseRepository<T> where T :class
 13     {
 14         private DbContext _dbContext;
 15         public BaseRepository(DbContext dbContext)
 16         {
 17             _dbContext = dbContext;
 18         }
 19
 20         /// <summary>
 21         /// 查询
 22         /// </summary>
 23         /// <param name="Id">主键</param>
 24         /// <returns>实体</returns>
 25         public T Find(int Id)
 26         {
 27             return _dbContext.Set<T>().Find(Id);
 28         }
 29     }
 30 }

二、业务逻辑层

回到Ninesky.Base项目中

1、添加项目引用

引用 上点右键->添加引用

在引用管理器中 勾选“Ninesky.DataLibrary”,点击确定

2、栏目服务类

添加类CategoryService,添加Find 方法,代码如下

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Linq;
  4 using System.Threading.Tasks;
  5 using Microsoft.EntityFrameworkCore;
  6 using Ninesky.DataLibrary;
  7
  8 namespace Ninesky.Base
  9 {
 10     /// <summary>
 11     /// 栏目服务类
 12     /// </summary>
 13     public class CategoryService
 14     {
 15         private BaseRepository<Category> _baseRepository;
 16         public CategoryService(DbContext dbContext)
 17         {
 18             _baseRepository = new BaseRepository<Category>(dbContext);
 19         }
 20
 21         /// <summary>
 22         /// 查找
 23         /// </summary>
 24         /// <param name="Id">栏目Id</param>
 25         /// <returns></returns>
 26         public Category Find(int Id)
 27         {
 28             return _baseRepository.Find(Id);
 29         }
 30     }

三、web层实现

回到Ninesky.Web项目中。

1、安装包引用

●安装EntityFrameworkCore.SqlServer包

Ninesky.Web项目的引用中右键-> 管理NuGet程序包

在对话框中选择浏览标签,搜索框中输入“EntityFrameworkCore”,然后找到”Microsoft.EntityFrameworkCore.SqlServer”点击安装.

注:此包提供SQL Server 数据库的支持

●安装Microsoft.EntityFrameworkCore.Tool包

在对话框中选择浏览标签,搜索框中输入“Microsoft.EntityFrameworkCore.Tool”,勾选包括预发行版本,然后找到”Microsoft.EntityFrameworkCore.Tool”点击安装。

注:此包提供数据迁移和更新数据库的支持。

2、设置连接字符串

在vs2015中选择视图->SQL Server对象管理器。

这里有两个实例,MSSQLLocalDB和ProectsV13.都是SQL Server 13.0.2151版本,有什么区别真不懂。

在SQL Server 上右键 –>添加SQL Server

在连接对话框中选择MSSQLLocalDB(反正不清楚区别,干脆选第一个不带版本号的),点高级。

复制连接字符串,打开appsettings.json,添加连接字符串的配置(红框部分)

3、添加数据上下文

Ninesky.Web项目上右键->添加->类,输入名称NineskyDbContext

引用 上点右键->添加引用。在引用管理器中 勾选“Ninesky.Base”,点击确定

打开CategoryController,using Ninesky.Base,在这是发现一个现象如下图:

这里自动出现了DataLibrary的命名空间,这个Web项目中本来没有引用DataLibrary,只引用了BaseBase中引用了DataLibrary项目。看样引用也会传染,试了一下在Base项目中卸载EntityFrameworkCore引用也可以正常使用EntityFrameworkCore功能,啊~啊~~啊~~~,大叫三声,干脆把WEB项目和Base项目中的都不要引用EntityFrameworkCore了,只要DataLibrary中引用就可以了。

完成后NineskyDbContext的代码如下:

  1 using Microsoft.EntityFrameworkCore;
  2 using Ninesky.Base;
  3
  4 namespace Ninesky.Web
  5 {
  6     public class NineskyDbContext:DbContext
  7     {
  8         public DbSet<Category> Categories { get; set; }
  9
 10         public NineskyDbContext(DbContextOptions options):base(options)
 11         {
 12
 13         }
 14     }
 15 }
 16 

4、注入NineskyDbContext

打开Startup.cs文件,在ConfigureServices方法中写入红框波分代码。

services.AddDbContext方法用来注入DbContext

options => options.UseSqlServer表示使用的是SqlServer数据库。(如果要连接MySql,在项目中引用MySql的EntityFrameworkCore包,然后再这里options => options.UseMySql(……)就可以了)。

Configuration.GetConnectionString("DefaultConnection")表示从配置文件中读取名为DefaultConnection的连接字符串。

5、启用迁移和创建数据库

●启用迁移

在菜单中选择工具->NuGet包管理器->程序包管理器控制台

在包管理器控制台中输入 Add-Migration Init 回车

完成后可以看到在项目中生成了Migrations文件夹,说明启用迁移成功。

●创建数据库。

在包管理器控制台中输入Update-Database 回车,以创建数据库。

完成后可以在SQL Server对象管理器看到成功创建了数据库和表

注:数据库文件默认不创建在项目中,下载的代码中不包含数据库文件,自己运行一下Update-Database命令就可以创建数据库了。另外V13的版本是SQL Server 2016版,我测试过在安装v12版本(2014版)的机子上运行Update-Database也可以创建数据库,其他的版本没试过,估计08R2以后的版本应该都没问题。

6、修改栏目控制器的Index方法

下一步就是回到CategoryController.cs中,修改代码如下:

  1 namespace Ninesky.Web.Controllers
  2 {
  3     /// <summary>
  4     /// 栏目控制器
  5     /// </summary>
  6     public class CategoryController : Controller
  7     {
  8         /// <summary>
  9         /// 数据上下文
 10         /// </summary>
 11         private NineskyDbContext _dbContext;
 12
 13         /// <summary>
 14         /// 栏目服务
 15         /// </summary>
 16         private CategoryService _categoryService;
 17
 18         public CategoryController(NineskyDbContext dbContext)
 19         {
 20             _dbContext = dbContext;
 21             _categoryService = new CategoryService(dbContext);
 22         }
 23
 24         /// <summary>
 25         /// 查看栏目
 26         /// </summary>
 27         /// <param name="id">栏目Id</param>
 28         /// <returns></returns>
 29         [Route("/Category/{id:int}")]
 30         public IActionResult Index(int id)
 31         {
 32             var category = _categoryService.Find(id);
 33             if (category == null) return View("Error");
 34             return View(category);
 35         }
 36     }
 37 }
 38 

栏目控制器的构造函数(public CategoryController(NineskyDbContext dbContext))有参数个NineskyDbContext,因为在Startup.cs中注入了NineskyDbContext,在控制器初始化的时候可以自动获取到这个参数。

Index方法通过categoryService查询对应id的栏目,并返回视图。

7、添加Index视图

在项目的Views文件夹上右键->添加->新建文件夹,输入名称Category

在新创建的的Category文件夹上右键->添加->新建项

选择MVC试图页,名称为Index.cshtml

添加完成后的视图。。。。

真干净啊,啥也没有。吐糟一下:以前在Action上点右键添加视图的方式多好,还可以根据模型生成代码,这下好了什么都要自己写,工作量大了不少。没办法自己写吧。简单写一下视图

  1 @model Ninesky.Base.Category
  2 @{
  3     ViewData["Title"] = Model.Name;
  4 }
  5
  6 <h2>@Model.Name</h2>
  7 <div class="row">
  8     <div class="col-lg-2 col-md-3">侧栏</div>
  9     <div class="col-lg-2 col-md-3">
 10         <ul class="list-group">
 11             <li class="list-group-item">
 12                 <label asp-for="CategoryId"></label>
 13                 @Html.DisplayFor(model => model.CategoryId)
 14             </li>
 15             <li class="list-group-item">
 16                 <label asp-for="Name"></label>
 17                 @Html.DisplayFor(model => model.Name)
 18             </li>
 19             <li class="list-group-item">
 20                 <label asp-for="ParentId"></label>
 21                 @Html.DisplayFor(model => model.ParentId)
 22             </li>
 23             <li class="list-group-item">
 24                 <label asp-for="Type"></label>
 25                 @Html.DisplayFor(model => model.Type)
 26             </li>
 27             <li class="list-group-item">
 28                 <label asp-for="Target"></label>
 29                 @Html.DisplayFor(model => model.Target)
 30             </li>
 31             <li class="list-group-item">
 32                 <label asp-for="Order"></label>
 33                 @Html.DisplayFor(model => model.Order)
 34             </li>
 35             <li class="list-group-item">
 36                 <label asp-for="Description"></label>
 37                 @Html.DisplayFor(model => model.Description)
 38             </li>
 39         </ul>
 40
 41     </div>
 42 </div>

8、插入一行测试数据

SQL Server对象管理器中查看表Categories数据,

在表中随便输入一条数据。

然后F5运行一下。可以看到刚才输入的数据已经取出来了。这里栏目类型直接显示了枚举CategoryType里的[Display(Name = "常规栏目")]值 确实是挺智能的。

四、其他

代码托管地址:https://git.oschina.net/ninesky/Ninesky

文章发布地址:http://www.ninesky.cn

http://mzwhj.cnblogs.com/

代码包下载:http://pan.baidu.com/s/1b2UI0e

时间: 2024-08-05 18:54:52

MVC Core 网站开发(Ninesky) 2.1、栏目的前台显示的相关文章

MVC Core 网站开发(Ninesky) 2.1、栏目的前台显示(补充)

在2.1.栏目的前台显示中因右键没有添加视图把微软给鄙视了一下,后来有仔细研究了一下发现应该鄙视自己,其实这个功能是有的,是自己没搞清楚乱吐糟. 其实只要在NuGet中安装两个包(Microsoft.VisualStudio.Web.CodeGeneration.Tools和Microsoft.VisualStudio.Web.CodeGenerators.Mvc)就可以了.如下图: 是不是熟悉的感觉又回来了.. 现在可以用右键的在弹出的对话框中添加视图了.在实际的使用中模板,可以选择Creat

MVC Core 网站开发(Ninesky) 1、创建项目

又要开一个新项目了!说来惭愧,以前的东西每次都没写完,不是不想写完,主要是我每次看到新技术出来我都想尝试一下,看到.Net Core 手又痒了,开始学MVC Core. MVC Core最吸引我的有三点: 跨平台:windows和linux都可以用,以后没必要让客服非得用windows服务器了 多数据库支持:这个是Entity framework Core的功能,提供SQL Server.SQlite.PostgreSQL,MySQL等多种数据库支持,在linux下用.Net MVC再也不用担心

MVC Core 网站开发(Ninesky) 2、栏目

栏目是网站的常用功能,按照惯例栏目分常规栏目,单页栏目,链接栏目三种类型,这次主要做添加栏目控制器和栏目模型两个内容,控制器这里会用到特性路由,模型放入业务逻辑层中(网站计划分数据访问.业务逻辑和Web层,初步计划划分如下图). 一.栏目控制器 1.添加控制器 在Ninesky.Web项目项目Controller文件夹点右键 添加->新建项 在添加新项对话框中选择MVC控制器类,名称输入CategoryController. 自动生成代码如下 1 using System; 2 using Sy

.Net Core MVC 网站开发(Ninesky) 2.3、项目架构调整-控制反转和依赖注入的使用

再次调整项目架构是因为和群友dezhou的一次聊天,我原来的想法是项目尽量做简单点别搞太复杂了,仅使用了DbContext的注入,其他的也没有写接口耦合度很高.和dezhou聊过之后我仔细考虑了一下,还是解耦吧,本来按照软件设计模式就应该是高内聚低耦合的,低耦合使项目的模块独立于其他模块,增加了可维护性和移植性! 注:前面写的博客详细记录没项目操作的每一步,其实写起博客来很费时间,而且整片博文里很多无用的信息.对MVC来说会添加控制器,添加视图,添加类这些都最基本的要求了,并且前面博文里都写了,

.Net Core跨平台开发入门---跨平台的简单实现

1,下载.Net Core For VS2015 https://www.microsoft.com/net/core#windows请大家牢记此地址,如果.NET core有最新版本官方也会在这里进行更新,现在最新版本1.0.1 2,安装.Net Core 安装时关闭VS2015,安装完毕之后打开VS即可看到 3,.Net Core开发不再使用传统的程序集,而是引入了包的概念 所有的依赖项都将基于包的概念,代码格式仍然是和以前的书写一样,大同小异. 环境布置:Ubuntu 16.04 使用ro

.Net Core MVC 网站开发(Ninesky) 2.3、项目架构调整(续)-使用配置文件动态注入

上次实现了依赖注入,但是web项目必须要引用业务逻辑层和数据存储层的实现,项目解耦并不完全:另一方面,要同时注入业务逻辑层和数据访问层,注入的服务直接写在Startup中显得非常臃肿.理想的方式是,web项目近引用接口而不引用实现,在配置文件中进行配置实现程序集合类,注入业务逻辑层而不必注入数据访问层. 一.数据访问层 在项目中摒弃数据访问层或者使用EntityFramework作为数据访问层. 在项目中数据访问层主要实现数据的存储,仔细看一下EntityFramework发现DbContext

MVC5 网站开发之八 栏目功能 添加、修改和删除

本次实现栏目的浏览.添加.修改和删除. 栏目一共有三种类型. 常规栏目-可以添加子栏目,也可以添加内容模型.当不选择内容模型时,不能添加内容. 单页栏目-栏目只有一个页面,可以设置视图. 链接栏目-栏目为一个链接,点击后转到相应链接. 在视图中原本栏目的树形显示插件使用Bootstrap TreeView 1.2.0(MVC5 网站开发之六 管理员 2.添加.删除.重置密码.修改密码.列表浏览),后来使用中发现zTree使用起来更习惯,所以更换成zTree了. 目录 MVC5网站开发之一 总体概

ASP.NET MVC 网站开发总结(一)

历经一个多月的努力,工作室的门户网站终于结束了内部公测. 仔细算一下,大概把网站开发出1.0版本大概用了一个月的时间(主要是利用课余时间),其后大概用了十几天来测试.完善.改进,最终定型.感觉最有难度的既不是后台代码的编写,也不是前台页面的编写,而是将不同人编写的前台和后台很好的拼接起来(当然若是前台和后台都是同一个人做,当然不存在这个问题^_^).这也是自己第一次与工作室的伙伴共同完成一个网站.简单的总结一下,团队开发网站需要注意的地方以及收获吧!(其中我主要的任务是后台代码编写以及后台与前台

asp.net mvc+jquery easyui开发实战教程之网站后台管理系统开发4- 后台模板html页面创建

上一篇教程<asp.net mvc+jquery easyui开发实战教程之网站后台管理系统开发3-登录模块开发>完成了本项目的登录模块,登录后就需要进入后台管理首页了,需要准备一个后台模板,本文主要讲解如何创建这个后台模板,本文创建的后台模板不集成到项目内部,只是静态html页面.后台模板是系统开发必须的,一般小公司有个3套后台模板就够用了.本项目后台模板主要是jquery easyui插件创建的,不需要美工设计就可以创建出来,而且效果还可以,具体效果图如下: 这个版面的缺点是,只能适应2层