abp(net core)+easyui+efcore實作倉儲管理系統目錄
abp(net core)+easyui+efcore實作倉儲管理系統——ABP總體介紹(一)
abp(net core)+easyui+efcore實作倉儲管理系統——解決方案介紹(二)
abp(net core)+easyui+efcore實作倉儲管理系統——領域層創建物體(三)
abp(net core)+easyui+efcore實作倉儲管理系統——定義倉儲并實作 (四)
abp(net core)+easyui+efcore實作倉儲管理系統——創建應用服務(五)
abp(net core)+easyui+efcore實作倉儲管理系統——展現層實作增刪改查之控制器(六)
abp(net core)+easyui+efcore實作倉儲管理系統——展現層實作增刪改查之串列視圖(七)
abp(net core)+easyui+efcore實作倉儲管理系統——展現層實作增刪改查之增刪改視圖(八)
abp(net core)+easyui+efcore實作倉儲管理系統——展現層實作增刪改查之選單與測驗(九)
abp(net core)+easyui+efcore實作倉儲管理系統——多語言(十)
abp(net core)+easyui+efcore實作倉儲管理系統——使用 WEBAPI實作CURD (十一)
abp(net core)+easyui+efcore實作倉儲管理系統——選單-上 (十六)
abp(net core)+easyui+efcore實作倉儲管理系統——選單-下(十七)
abp(net core)+easyui+efcore實作倉儲管理系統——EasyUI前端頁面框架 (十八)
abp(net core)+easyui+efcore實作倉儲管理系統——EasyUI之貨物管理一 (十九)
abp(net core)+easyui+efcore實作倉儲管理系統——EasyUI之貨物管理二 (二十)
abp(net core)+easyui+efcore實作倉儲管理系統——EasyUI之貨物管理三 (二十一)
從篇 abp(net core)+easyui+efcore實作倉儲管理系統——EasyUI前端頁面框架 (十八) 至abp(net core)+easyui+efcore實作倉儲管理系統——EasyUI之貨物管理三 (二十一) 為止,我們已經通過EasyUI完成了貨物資訊管理的前端與后臺功能,現在我們運行起應用程式實測一下,
十一、瀏覽貨物管理頁面
1.在Visual Studio 2017中按F5運行應用程式,
2.在瀏覽器中的地址欄中輸入“http://localhost:5000/”,然后輸入管理員用戶名進行登錄,
3.在主界面的選單中,選擇“Business->貨物管理”選單項,瀏覽器中呈現一個貨物資訊串列與四個按鈕,如下圖,關于選單的生成可以參見文章(abp(net core)+easyui+efcore實作倉儲管理系統——選單-上 (十六) 與 abp(net core)+easyui+efcore實作倉儲管理系統——選單-下(十七) ), 
4.資料庫中有資料,卻沒有顯示,我們在瀏覽器中按F12,查看一下回傳的是什么結果?如下圖,回傳結果被ABP封裝了一下,

我們來看上圖中紅框所標示的結果中可以看出,其中result為代碼中指定回傳的資料,其他幾個鍵值對是ABP封裝的,包含了是否認證、是否成功、錯誤資訊,以及目標Url,
5.我們不需要ABP對json進行封裝怎么辦?很簡單,只需要在方法上標記[DontWrapResult]特性即可,這個特性其實是一個快捷方式用來告訴ABP不要用AbpJsonResult對我們的結果進行封裝,
6. 在Visual Studio 2017的“解決方案資源管理器”中,右鍵單擊在領域層“ABP.TPLMS.Web.Mvc”專案中的Controller目錄, 找到CargoController檔案,在List方法上添加[DontWrapResult]特性,
7. 在Visual Studio 2017中按F5運行應用程式,登錄之后,點擊“[貨物管理]”選單,我們可以看到貨物管理串列頁面,ABP是不再對JSON結果進行封裝,界面中也能顯示記錄行了,但是記錄行中沒有資料,如下圖,

十二、創建JSONHelper輔助類
我們在之前的測驗貨物資訊管理功能時,看到貨物管理串列頁面中只顯示了記錄行,沒有顯示相關的資料,接下來我們來解決這個問題,我們需要一個J SON的輔助類,
1. 在Visual Studio 2017的“解決方案資源管理器”中,右鍵單擊在領域層“ABP.TPLMS.Web.Core”專案,選擇“添加” > “新建檔案夾”,并重命名為“Helpers”,
2. 在Visual Studio 2017的“解決方案資源管理器”中,滑鼠右鍵單擊“Helpers”檔案夾,然后選擇“添加” > “類…”, 在“添加新項-ABP.TPLMS.Web.Core”對話框中,選擇“類”,并將名稱命名為JsonHeplerl,
3. 在我們剛才創建的JsonHeplerl檔案中,撰寫如下代碼:
using Newtonsoft.Json; using Newtonsoft.Json.Converters; using System; using System.Collections.Generic; using System.Text; namespace ABP.TPLMS.Helpers { public class JsonHelper { private static JsonHelper _jsonHelper = new JsonHelper(); public static JsonHelper Instance { get { return _jsonHelper; } } public string Serialize(object obj) { return JsonConvert.SerializeObject(obj, new IsoDateTimeConverter { DateTimeFormat = "yyyy-MM-dd HH:mm:ss" }); } public string SerializeByConverter(object obj, params JsonConverter[] converters) { return JsonConvert.SerializeObject(obj, converters); } public T Deserialize<T>(string input) { return JsonConvert.DeserializeObject<T>(input); } public T DeserializeByConverter<T>(string input, params JsonConverter[] converter) { return JsonConvert.DeserializeObject<T>(input, converter); } public T DeserializeBySetting<T>(string input, JsonSerializerSettings settings) { return JsonConvert.DeserializeObject<T>(input, settings); } private object NullToEmpty(object obj) { return null; } } }
十三、修改CargoController與TPLMSControllerBase
我們對(abp(net core)+easyui+efcore實作倉儲管理系統——EasyUI之貨物管理二 (二十) )文中所寫方法JsonEasyUI進行改造,
1. 在Visual Studio 2017的“解決方案資源管理器”中,右鍵單擊在領域層“ABP.TPLMS.Web.Core”專案中的Controller目錄, 找到TPLMSControllerBase檔案,中的JsonEasyUI方法,更新其中的代碼,代碼如下,
protected dynamic JsonEasyUI(dynamic t,int total) { var obj= new { total = total, rows = t }; var json = ABP.TPLMS.Helpers.JsonHelper.Instance.Serialize(obj); return json; }
2. 在Visual Studio 2017的“解決方案資源管理器”中,右鍵單擊在領域層“ABP.TPLMS.Web.Mvc”專案中的Controller目錄, 找到CargoController.cs檔案,修改List方法,如下代碼,
[DontWrapResult] public string List() { var page = Request.Form["page"].ToString(); var size = Request.Form["rows"].ToString(); int pageIndex = page == null ? 1 : int.Parse(page); int pageSize = size == null ? 20 : int.Parse(size); PagedCargoResultRequestDto paged = new PagedCargoResultRequestDto(); paged.MaxResultCount = pageSize; paged.SkipCount = ((pageIndex-1)<0?0: pageIndex - 1) * pageSize; var userList = _cargoAppService.GetAll(paged).GetAwaiter().GetResult().Items; int total = 1000; var json = JsonEasyUI(userList,total); return json; }
3. 在Visual Studio 2017中按F5運行應用程式,登錄之后,點擊“[貨物管理]”選單,我們可以看到貨物管理串列頁面,如下圖,

4.我們在瀏覽器中按F12,查看一下回傳的是什么結果?如下圖,回傳結果沒有被ABP封裝,

轉載請註明出處,本文鏈接:https://www.uj5u.com/net/105811.html
標籤:.NET Core
