MVC Core 網站開發(Ninesky) 2、欄目

来源:http://www.cnblogs.com/mzwhj/archive/2016/12/04/6132329.html
-Advertisement-
Play Games

欄目是網站的常用功能,按照慣例欄目分常規欄目,單頁欄目,鏈接欄目三種類型,這次主要做添加欄目控制器和欄目模型兩個內容,控制器這裡會用到特性路由,模型放入業務邏輯層中(網站計劃分數據訪問、業務邏輯和Web層,初步計劃劃分如下圖)。 一、欄目控制器 1、添加控制器 在Ninesky.Web項目項目Con... ...


欄目是網站的常用功能,按照慣例欄目分常規欄目,單頁欄目,鏈接欄目三種類型,這次主要做添加欄目控制器和欄目模型兩個內容,控制器這裡會用到特性路由,模型放入業務邏輯層中(網站計劃分數據訪問、業務邏輯和Web層,初步計劃劃分如下圖)。

模塊功能劃分

一、欄目控制器

1、添加控制器

Ninesky.Web項目項目Controller文件夾點右鍵 添加->新建項

image

在添加新項對話框中選擇MVC控制器類,名稱輸入CategoryController.

image

自動生成代碼如下

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Linq;
  4 using System.Threading.Tasks;
  5 using Microsoft.AspNetCore.Mvc;
  6 
  7 
  8 namespace Ninesky.Web.Controllers
  9 {
 10     /// <summary>
 11     /// 欄目控制器
 12     /// </summary>
 13     public class CategoryController : Controller
 14     {
 15         // GET: /<controller>/
 16         public IActionResult Index()
 17         {
 18             return View();
 19         }
 20     }
 21 }
 22 

 

2、使用特性路由。

改造一下Index方法,使其接受id參數,返回id字元串形式。

  1  public IActionResult Index(int id)
  2         {
  3             return Content(id.ToString());
  4         }

運行效果

image

這裡生成的地址index感覺累贅,如果把index去掉顯示效果會更好。

為index方法添加特性路由,添加完成代碼如下:

  1         // GET: /<controller>/
  2         [Route("/Category/{id:int}")]
  3         public IActionResult Index(int id)
  4         {
  5             return Content(id.ToString());
  6         }

[Route("/Category/{id:int}")]表示路由形式為/catgory/id參數,id參數只接受int類型。F5運行效果如下

image

 

二、添加模型

1、新建Base項目

解決方案(Ninesky)上點右鍵->添加->新建項目

image

選擇.NET Core –> Class Library(.NET Core)

名稱輸入:Ninesky.Base(這裡添加了一個新項目,是考慮到項目分層,Web項目負責顯示,地下有業務邏輯和數據存儲的層。 我把欄目相關的模型,業務邏輯放到Base項目中。)

 

image

Base項目中將預設生成的Class1改名為Category。

2、為項目添加EntityFrameworkCore包

Ninesky.Base項目的引用中右鍵-> 管理NuGet程式包

 

image

在對話框中選擇瀏覽標簽,搜索框中輸入“EntityFrameworkCore”,然後找到”Microsoft.EntityFrameworkCore”點擊安裝。

image

 

這裡安裝的是EntityFrameworkCore的1.1版本,需要NETStandard.Library1.6.1版本的支持,而項目自帶的是NETStandard.Library1.60版本,所以出現了嘆號。

image

再次進入Nuget管理器中巴NETStandard.Library的版本更新一下,嘆號立即消失。

image

3、添加欄目類型

欄目類型是個枚舉(General,Page,Link)

欄目類型:常規欄目,單頁欄目,鏈接欄目。

常規欄目:可以添加子欄目,設置內容模型後可以添加相應內容。

單頁欄目:只一個頁面,頁面可以設置頁面內容。

鏈接欄目:一個轉向鏈接。

Ninesky.Base項目中右鍵->添加->。 輸入類名”CategoryType

image

將代碼修改如下

  1  using System.ComponentModel.DataAnnotations;
  2 
  3 namespace Ninesky.Base
  4 {
  5     /// <summary>
  6     /// 欄目類型
  7     /// </summary>
  8     public enum CategoryType
  9     {
 10         [Display(Name = "常規欄目")]
 11         General,
 12         [Display(Name = "單頁欄目")]
 13         Page,
 14         [Display(Name = "鏈接欄目")]
 15         Link
 16     }
 17 }
 18 

 

4、添加欄目模型

4.1、公共模型類

打開Category.CS,修改代碼如下:

  1 using System.ComponentModel.DataAnnotations;
  2 
  3 namespace Ninesky.Base
  4 {
  5     /// <summary>
  6     /// 欄目模型
  7     /// </summary>
  8     public class Category
  9     {
 10         [Key]
 11         public int CategoryId { get; set; }
 12 
 13         /// <summary>
 14         /// 欄目名稱
 15         /// </summary>
 16         [Required]
 17         [StringLength(50)]
 18 
 19         public string Name { get; set; }
 20 
 21         /// <summary>
 22         /// 欄目類型
 23         /// </summary>
 24         [Required]
 25         [Display(Name= "欄目類型")]
 26         public CategoryType Type { get; set; }
 27 
 28         /// <summary>
 29         /// 上級欄目ID
 30         /// </summary>
 31         /// <remarks>
 32         /// 0-表示本欄目是根欄目,無上級欄目
 33         /// </remarks>
 34         [Required]
 35         [Display(Name = "上級欄目")]
 36         public int ParentId { get; set; }
 37 
 38         /// <summary>
 39         /// 排序
 40         /// </summary>
 41         /// <remarks>
 42         /// 數字越小越靠前
 43         /// </remarks>
 44         [Required]
 45         [Display(Name = "排序")]
 46         public int Order { get; set; }
 47 
 48         /// <summary>
 49         /// 打開目標
 50         /// </summary>
 51         [Required]
 52         [StringLength(20)]
 53         [Display(Name = "打開目標")]
 54         public string Target { get; set; }
 55 
 56         /// <summary>
 57         /// 欄目說明
 58         /// </summary>
 59         [Required]
 60         [StringLength(1000)]
 61         [Display(Name = "欄目說明")]
 62         public string Description { get; set; }
 63     }
 64 }

4.2添加常規欄目模型

Ninesky.Base項目中右鍵->添加->。 輸入類名”CategoryGeneral”,代碼如下:

  1 using System.ComponentModel.DataAnnotations;
  2 
  3 namespace Ninesky.Base
  4 {
  5     /// <summary>
  6     /// 常規欄目模型
  7     /// </summary>
  8     public class CategoryGeneral
  9     {
 10         [Key]
 11         public int GeneralId { get; set; }
 12 
 13         /// <summary>
 14         /// 欄目ID
 15         /// </summary>
 16         [Required]
 17         [Display(Name = "欄目ID")]
 18         public int CategoryId { get; set; }
 19 
 20         /// <summary>
 21         /// 欄目視圖
 22         /// </summary>
 23         [Required]
 24         [StringLength(200)]
 25         [Display(Name = "欄目視圖")]
 26         public string View { get; set; }
 27 
 28         /// <summary>
 29         /// 模塊名稱
 30         /// </summary>
 31         [Required]
 32         [StringLength(50)]
 33         [Display(Name = "模塊名稱")]
 34         public string Module { get; set; }
 35 
 36         /// <summary>
 37         /// 內容視圖
 38         /// </summary>
 39         [Required]
 40         [StringLength(200)]
 41         [Display(Name = "內容視圖")]
 42         public string ContentView { get; set; }
 43 
 44         /// <summary>
 45         /// 內容排序
 46         /// </summary>
 47         [Required]
 48         [StringLength(200)]
 49         [Display(Name = "內容排序")]
 50         public int? ContentOrder { get; set; }
 51 
 52         /// <summary>
 53         /// 欄目
 54         /// </summary>
 55         public virtual Category Category { get; set; }
 56     }
 57 }
 58 

4.3添加單頁欄目模型

Ninesky.Base項目中右鍵->添加->。 輸入類名”CategoryPage”,代碼如下:

  1 using System.ComponentModel.DataAnnotations;
  2 
  3 namespace Ninesky.Base
  4 {
  5     public class CategoryPage
  6     {
  7         [Key]
  8         public int PageId { get; set; }
  9 
 10         /// <summary>
 11         /// 欄目ID
 12         /// </summary>
 13         [Required]
 14         [Display(Name = "欄目ID")]
 15         public int CategoryId { get; set; }
 16 
 17         /// <summary>
 18         /// 欄目內容
 19         /// </summary>
 20         [Required]
 21         [StringLength(10000)]
 22         [Display(Name = "欄目內容")]
 23         public string Content { get; set; }
 24 
 25         /// <summary>
 26         /// 欄目視圖
 27         /// </summary>
 28         [Required]
 29         [StringLength(200)]
 30         [Display(Name = "欄目視圖")]
 31         public string View { get; set; }
 32 
 33         /// <summary>
 34         /// 欄目
 35         /// </summary>
 36         public virtual Category Category { get; set; }
 37 
 38         public CategoryPage()
 39         {
 40             View = "Index";
 41         }
 42     }
 43 }
 44 

4.4添加鏈接欄目模型

Ninesky.Base項目中右鍵->添加->。 輸入類名”CategoryLink”,代碼如下:

  1 using System.ComponentModel.DataAnnotations;
  2 
  3 namespace Ninesky.Base
  4 {
  5     /// <summary>
  6     /// 鏈接欄目模型
  7     /// </summary>
  8     public class CategoryLink
  9     {
 10         [Key]
 11         public int LinkId { get; set; }
 12 
 13         /// <summary>
 14         /// 欄目ID
 15         /// </summary>
 16         [Required]
 17         [Display(Name = "欄目ID")]
 18         public int CategoryId { get; set; }
 19 
 20         /// <summary>
 21         /// 欄目地址
 22         /// </summary>
 23         [Required]
 24         [DataType(DataType.Url)]
 25         [StringLength(500)]
 26         [Display(Name = "欄目地址")]
 27         public string Url { get; set; }
 28     }
 29 }
 30 

返回到公共模型Category.CS中,在底部添加外鍵

  1         /// <summary>
  2         /// 欄目說明
  3         /// </summary>
  4         [Required]
  5         [StringLength(1000)]
  6         [Display(Name = "欄目說明")]
  7         public string Description { get; set; }
  8 
  9 //添加的導航屬性
 10         /// <summary>
 11         /// 常規欄目
 12         /// </summary>
 13         public virtual CategoryGeneral General { get; set; }
 14 
 15         /// <summary>
 16         /// 單頁欄目
 17         /// </summary>
 18         public virtual CategoryPage Page { get; set; }
 19 
 20         /// <summary>
 21         /// 鏈接欄目
 22         /// </summary>
 23         public virtual CategoryLink Link { get; set; }
 24 //添加的導航屬性結束
 25     }
 26 }
 27 

三、其他

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

文章發佈地址:http://www.ninesky.cn

                    http://mzwhj.cnblogs.com/

代碼包下載:http://pan.baidu.com/s/1dFBmg0p


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 下載JProfiler包 wget http://download-keycdn.ej-technologies.com/jprofiler/jprofiler_linux_9_2.rpm 安裝JProfiler rpm -ivh jprofiler_linux_9_2.rpm 安裝JProfile ...
  • 每次搭建新伺服器,都要來來回回把這些包再裝一下,來來回回搞了不下20遍了吧,原來都是憑經驗,配置過程中重覆入坑是難免的,故寫此文做個備忘。雖然有像xampp這樣的集成包,但是在生產環境的Linux發行版上,還是通過包管理工具安裝會放心。這次新買的伺服器是CentOS 7(7.2)系統,相關配置也都以 ...
  • 系統環境:CentOS 6.6 首先查看伺服器上是否已安裝了svn # rpm -qa subversion 如果沒有安裝,則執行此命令 # yum list subversion //查看svn包名 # yum install -y subversion.x86_64 //yum安裝svn 創建s ...
  • orch的目標是在建立科學演算法的同時,要有最大的靈活性和速度,而這一過程非常簡單。Torch擁有一個大社區驅動包的生態系統,涉及機器學習、電腦視覺、信號處理、並行處理、圖像、視頻、音頻和網路等,並建立在Lua社區基礎之上。 ...
  • 當初在shell中, 看到">&1"和">&2"始終不明白什麼意思.經過在網上的搜索得以解惑.其實這是兩種輸出. 在 shell 程式中,最常使用的 FD (file descriptor) 大概有三個, 分別是: 0 是一個文件描述符,表示標準輸入(stdin)1 是一個文件描述符,表示標準輸出( ...
  • 在《曆數依賴註入的N種玩法》演示系統自動註冊服務的實例中,我們會發現輸出的列表包含兩個特殊的服務,它們的對應的服務介面分別是IApplicationLifetime和IHostingEnvironment,我們將分別實現這兩個介面的服務統稱在ApplicationLifetime和HostingEn... ...
  • 先看效果: 1.本文演示的是微信【企業號】的H5頁面微信支付 2.本項目基於開源微信框架WeiXinMPSDK開發:https://github.com/JeffreySu/WeiXinMPSDK 感謝作者蘇志巍的開源精神 一、準備部分 相關參數: AppId:公眾號的唯一標識(登陸微信企業號後臺 ...
  • 題外話 本篇分享不能幫助你入門vue,入門的文章也是無意義的,官方文檔http://cn.vuejs.org/v2/guide/ 已經寫的不能再清晰了。希望我們勇敢的主動地給自己創造實踐的機會。 手裡有一個功能還不是很多的PC端頁面,考慮到下一個版本,要把IOS,安卓和公眾號上擁有的功能也要添加到P ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...