ASP.NET Core+Element+SQL Server開發校園圖書管理系統(二)

来源:https://www.cnblogs.com/hsiang/archive/2023/01/26/17058450.html
-Advertisement-
Play Games

隨著技術的進步,跨平臺開發已經成為了標配,在此大背景下,ASP.NET Core也應運而生。本文主要基於ASP.NET Core+Element+Sql Server開發一個校園圖書管理系統為例,簡述基於MVC三層架構開發的常見知識點,前一篇文章,已經簡單介紹瞭如何搭建開發框架,和登錄功能實現,本篇... ...


隨著技術的進步,跨平臺開發已經成為了標配,在此大背景下,ASP.NET Core也應運而生。本文主要基於ASP.NET Core+Element+Sql Server開發一個校園圖書管理系統為例,簡述基於MVC三層架構開發的常見知識點,前一篇文章,已經簡單介紹瞭如何搭建開發框架,和登錄功能實現,本篇文章繼續講解主頁面的開發,僅供學習分享使用,如有不足之處,還請指正。

涉及知識點

在本示例中,應用最多的就是如何Element中提供的組件,和控制器中業務邏輯處理,涉及知識點如下所示:

  • MVC 是一種使用 MVC(Model View Controller 模型-視圖-控制器)設計創建 Web 應用程式的模式,其中Controller(控制器)處理輸入(寫入資料庫記錄)。控制器Controller,是應用程式中處理用戶交互的部分,通常控制器負責從視圖讀取數據,控制用戶輸入,並向模型發送數據。
  • Element組件庫,一套為開發者、設計師和產品經理準備的基於 Vue 2.0 的桌面端組件庫。可以大大提高開發效率,減少工作量。在主頁面中,主要用到如下幾種:
    • 容器佈局el-container組件,用於佈局的容器組件,主要包含:<el-header>:頂欄容器。<el-aside>:側邊欄容器。<el-main>:主要區域容器。<el-footer>:底欄容器。可以進行不同組合,佈局出管理系統通用頁面(如,上中下結構,上(左右)下結構等)。
    • 導航菜單el-menu組件,為網站提供導航功能的菜單。有頂欄,側欄,摺疊等不同用法。
  • axios組件,是一個基於promise 的網路請求庫,axios本質上也是對原生XHR的封裝,只不過它是Promise的實現版本,符合最新的ES規範。在本示例中,所有的前後端交互,均是通過axios庫。

核心源碼

1. 組件引入

因為使用了Element提供的組件,大大節約了工作量,可以專註於業務邏輯的處理。引入組件庫也非常簡單,在客戶端庫安裝以後【具體安裝可參考前一篇文章】,直接在視圖中進行引用即可,如下所示:

 1 <head>
 2     <title>校園圖書管理系統</title>
 3     <!-- For-Mobile-Apps-and-Meta-Tags -->
 4     <meta name="viewport" content="width=device-width, initial-scale=1" />
 5     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 6     
 7     <!-- 引入樣式 -->
 8     <link rel="stylesheet" href="/lib/element-ui/theme-chalk/index.min.css">
 9     <!-- 引入組件庫 -->
10     <script src="/lib/vue/dist/vue.min.js"></script>
11     <script src="/lib/element-ui/index.min.js"></script>
12     <script src="/lib/axios/axios.min.js"></script>
13 </head>

2. 頁面佈局

頁面佈局採用el-container,代碼結構清晰明瞭,易於理解,如下所示:

 1 <div id="app">
 2     <el-container style="height:100vh; margin:0px;">
 3       <el-header style="background:url('/imgs/banner.jpg');height:120px;">
 4           <h1>
 5               校園圖書管理系統  Campus Library Management System
 6           </h1>
 7           <div style="text-align:right;position:relative;bottom:30px;">
 8               <el-link type="info" style="color:white;" href="/Home/Welcome" target="content">首頁</el-link>|
 9               <el-link type="info" style="color:white;" href="/Personal"  target="content">{{nickName}}</el-link>|
10               <el-link type="info" style="color:white;">退出</el-link>
11           </div>
12       </el-header>
13       <el-container>
14         <el-aside width="200px">
15             <el-menu
16               default-active="activeIndex"
17               class="el-menu-vertical-demo"
18               v-on:open="handleOpen"
19               v-on:close="handleClose"
20               v-on:select="handleSelect"
21               background-color="#545c64"
22               text-color="#fff"
23               active-text-color="#ffd04b">
24               <el-submenu :index="index" v-for="(right,index) in rights">
25                 <template slot="title">
26                   <span>{{right.menuName}}</span>
27                 </template>
28                 <el-menu-item index="1-1" v-for="(menu,index) in right.Menus">
29                     <el-link type="primary" underline="false" :href="menu.url" target="content">{{menu.menuName}}</el-link>
30                 </el-menu-item>
31               </el-submenu>
32             </el-menu>
33         </el-aside>
34         <el-container>
35           <el-main name="main" style="padding:0px;">
36               <iframe name="content" id="content" style="border:0px;width:100%;height:100%;margin:0px;background:white; padding:0px;" src="/Home/Welcome">
37                   
38               </iframe>
39           </el-main>
40           <el-footer style="background:#409EFF;">
41               <p style="color:white;"> &copy; 2022-2023 校園圖書管理系統. All Rights Reserved | Design by 小六公子</p>
42           </el-footer>
43         </el-container>
44       </el-container>
45     </el-container>
46 </div>

3. 數據交互

數據交互通過JS腳本進行,書寫格式和VUE2.0保持一致,在頁面啟動時,載入用戶所擁有的導航菜單,並綁定到el-menu對象,所以需要在mounted函數中增加調用向伺服器端發出請求,如下所示:

 1 <script>
 2    var app= new Vue({
 3         el: '#app',
 4         data:function() {
 5           return {
 6             activeIndex:'/',
 7             rights:[],
 8             nickName:'',
 9           }
10         },
11         mounted:function(){
12             this.handleLoadInfo();
13             this.handleLoadRights();
14         },
15         methods: {
16           handleOpen(key, keyPath) {
17             console.log(key, keyPath);
18           },
19           handleClose(key, keyPath) {
20             console.log(key, keyPath);
21           },
22           handleSelect(index,indexPath){
23             this.activeIndex=index;
24             console.log("index="+index+",indexPath="+indexPath);
25           },
26           handleLoadRights(){
27             var that = this;
28             that.rights=[];
29             console.log("query");
30             axios.get('/Home/GetUserRights', {params:{}}).then(function (response) {
31                 if(response.status==200){
32                     var data = response.data;
33                     let parentMenus=data.filter(function(e){
34                         return e.parentId==null;
35                     });
36                     for(let index=0;index< parentMenus.length;index++){
37                         let parentMenu=parentMenus[index];
38                         let pId=parentMenu.id;
39                         console.log(pId);
40                         let menus = data.filter(function(e){
41                             return e.parentId==pId;
42                         });
43                         console.log(menus);
44                         parentMenu.Menus=menus;
45                         that.rights.push(parentMenu);
46                     }
47                     console.log(that.rights);
48                 }
49                 console.log(response);
50             }).catch(function (error) {
51                 console.log(error);
52             });
53           },
54           handleLoadInfo(){
55             var that =this;
56             axios.get('/User/GetPersonalInfo', {params:{}}).then(function (response) {
57                 if(response.status==200){
58                     var data = response.data;
59                     that.nickName=data.nickName;
60                 }
61                 console.log(response);
62             }).catch(function (error) {
63                 console.log(error);
64             });
65           }
66         }
67       });
68 </script>

4. 控制器邏輯

主頁面控制器【HomeCotroller】邏輯主要通過登錄的ID,獲取對應的許可權菜單,然後返回給客戶端,如下所示:

 1 namespace CLMS.Controllers
 2 {
 3     public class HomeController : Controller
 4     {
 5         private readonly ILogger<HomeController> _logger;
 6 
 7         private DataContext dataContext;
 8 
 9         public HomeController(ILogger<HomeController> logger, DataContext context)
10         {
11             _logger = logger;
12             dataContext = context;
13         }
14 
15         public IActionResult Index()
16         {
17             int? userId = HttpContext.Session.GetInt32("UserId");
18             //判斷是否登錄
19             if (userId != null)
20             {
21 
22                 var user = dataContext.Users.FirstOrDefault(u => u.Id == userId);
23                 if (user != null)
24                 {
25                     ViewBag.NickName = user.NickName;
26                     ViewBag.UserRights = GetUserRights();
27                 }
28                 return View();
29             }
30             else
31             {
32                 return Redirect("/Login");
33             }
34 
35         }
36 
37         public IActionResult Welcome()
38         {
39             return View();
40         }
41 
42         [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
43         public IActionResult Error()
44         {
45             return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });
46         }
47 
48         [HttpGet]
49         public List<UserRight> GetUserRights()
50         {
51             int? userId = HttpContext.Session.GetInt32("UserId");
52             if (userId != null)
53             {
54                 var query = from u in dataContext.UserRoles
55                             join r in dataContext.Roles on u.RoleId equals r.Id
56                             join x in dataContext.RoleMenus on r.Id equals x.RoleId
57                             join m in dataContext.Menus on x.MenuId equals m.Id
58                             where u.UserId == userId
59                             select new UserRight { Id = m.Id, RoleName = r.Name, MenuName = m.Name, Url = m.Url, ParentId = m.ParentId, SortId = m.SortId };
60 
61                 return query.ToList();
62             }
63             return null;
64         }
65 
66         /// <summary>
67         /// 退出
68         /// </summary>
69         public IActionResult Logout()
70         {
71             HttpContext.Session.Clear();
72             return Redirect("/Login");
73         }
74     }
75 }

運行測試

導航菜單主要分為圖書管理,書室管理,系統管理三大塊,可以摺疊展開。主頁面開發完成後,運行測試。如下所示:

 

以上就是校園圖書管理系統的主頁面功能實現,功能正在開發完善中,後續功能再繼續介紹。旨在拋磚引玉,一起學習,共同進步。


作者:小六公子
出處:http://www.cnblogs.com/hsiang/
本文版權歸作者和博客園共有,寫文不易,支持原創,歡迎轉載【點贊】,轉載請保留此段聲明,且在文章頁面明顯位置給出原文連接,謝謝。
關註個人公眾號,定時同步更新技術及職場文章


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

-Advertisement-
Play Games
更多相關文章
  • 測試一、虛繼承與繼承的區別 1.1 單個繼承,不帶虛函數 1>class B size(8): 1> + 1> 0 | + (base class A) 1> 0 | | _ia //4B 1> | + 1> 4 | _ib //4B 有兩個int類型數據成員,占8B,基類邏輯存在前面 1.2、單個 ...
  • AOP-03 7.AOP-切入表達式 7.1切入表達式的具體使用 1.切入表達式的作用: 通過表達式的方式定義一個或多個具體的連接點。 2.語法細節: (1)切入表達式的語法格式: execution([許可權修飾符] [返回值類型] [簡單類名/全類名] [方法名]([參數列表]) 若目標類、介面與 ...
  • 這次設計一個通用的多位元組SPI介面模塊,特點如下: 可以設置為1-128位元組的SPI通信模塊 可以修改CPOL、CPHA來進行不同的通信模式 可以設置輸出的時鐘 狀態轉移圖和思路與多位元組串口發送模塊一樣,這裡就不給出了,具體可看該隨筆。 一、模塊代碼 1、需要的模塊 通用8位SPI介面模塊 `tim ...
  • 簡介: 享元模式,屬於結構型的設計模式。運用共用技術有效地支持大量細粒度的對象。 適用場景: 具有相同抽象但是細節不同的場景中。 優點: 把公共的部分分離為抽象,細節依賴於抽象,符合依賴倒轉原則。 缺點: 增加複雜性。 代碼: //用戶類 class User { private $name; fu ...
  • 【前置內容】Spring 學習筆記全系列傳送門: Spring學習筆記 - 第一章 - IoC(控制反轉)、IoC容器、Bean的實例化與生命周期、DI(依賴註入) Spring學習筆記 - 第二章 - 註解開發、配置管理第三方Bean、註解管理第三方Bean、Spring 整合 MyBatis 和 ...
  • 簡介: 中介者模式,屬於行為型的設計模式。用一個中介對象來封裝一系列的對象交互。中介者是各對象不需要顯式地相互引用,從而使其耦合鬆散,而且可以獨立地改變他們之間的交互。 適用場景: 如果平行對象間的依賴複雜,可以使用中介者解耦。 優點: 符合迪米特法則,減少成員間的依賴。 缺點: 不適用於系統出現對 ...
  • 這篇文章主要描述RPC的路由策略,包括為什麼需要請求隔離,為什麼不在註冊中心中實現請求隔離以及不同粒度的路由策略。 ...
  • 這道題只要會自定義cmp恰當地進行排序,其他部分沒有什麼大問題。 上代碼: 1 #include<bits/stdc++.h> 2 using namespace std; 3 int n,s,h1,h2,cnt; 4 struct apple{ 5 int height,ns;//height為蘋 ...
一周排行
    -Advertisement-
    Play Games
  • 1、預覽地址:http://139.155.137.144:9012 2、qq群:801913255 一、前言 隨著網路的發展,企業對於信息系統數據的保密工作愈發重視,不同身份、角色對於數據的訪問許可權都應該大相徑庭。 列如 1、不同登錄人員對一個數據列表的可見度是不一樣的,如數據列、數據行、數據按鈕 ...
  • 前言 上一篇文章寫瞭如何使用RabbitMQ做個簡單的發送郵件項目,然後評論也是比較多,也是準備去學習一下如何確保RabbitMQ的消息可靠性,但是由於時間原因,先來說說設計模式中的簡單工廠模式吧! 在瞭解簡單工廠模式之前,我們要知道C#是一款面向對象的高級程式語言。它有3大特性,封裝、繼承、多態。 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 介紹 Nodify是一個WPF基於節點的編輯器控制項,其中包含一系列節點、連接和連接器組件,旨在簡化構建基於節點的工具的過程 ...
  • 創建一個webapi項目做測試使用。 創建新控制器,搭建一個基礎框架,包括獲取當天日期、wiki的請求地址等 創建一個Http請求幫助類以及方法,用於獲取指定URL的信息 使用http請求訪問指定url,先運行一下,看看返回的內容。內容如圖右邊所示,實際上是一個Json數據。我們主要解析 大事記 部 ...
  • 最近在不少自媒體上看到有關.NET與C#的資訊與評價,感覺大家對.NET與C#還是不太瞭解,尤其是對2016年6月發佈的跨平臺.NET Core 1.0,更是知之甚少。在考慮一番之後,還是決定寫點東西總結一下,也回顧一下.NET的發展歷史。 首先,你沒看錯,.NET是跨平臺的,可以在Windows、 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 添加節點(nodes) 通過上一篇我們已經創建好了編輯器實例現在我們為編輯器添加一個節點 添加model和viewmode ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...
  • 類型檢查和轉換:當你需要檢查對象是否為特定類型,並且希望在同一時間內將其轉換為那個類型時,模式匹配提供了一種更簡潔的方式來完成這一任務,避免了使用傳統的as和is操作符後還需要進行額外的null檢查。 複雜條件邏輯:在處理複雜的條件邏輯時,特別是涉及到多個條件和類型的情況下,使用模式匹配可以使代碼更 ...
  • 在日常開發中,我們經常需要和文件打交道,特別是桌面開發,有時候就會需要載入大批量的文件,而且可能還會存在部分文件缺失的情況,那麼如何才能快速的判斷文件是否存在呢?如果處理不當的,且文件數量比較多的時候,可能會造成卡頓等情況,進而影響程式的使用體驗。今天就以一個簡單的小例子,簡述兩種不同的判斷文件是否... ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...