abp(net core)+easyui+efcore實現倉儲管理系統——EasyUI之貨物管理四 (二十二)

来源:https://www.cnblogs.com/chillsrc/archive/2019/10/15/11679387.html
-Advertisement-
Play Games

從篇 abp(net core)+easyui+efcore實現倉儲管理系統——EasyUI前端頁面框架 (十八) 至abp(net core)+easyui+efcore實現倉儲管理系統——EasyUI之貨物管理三 (二十一) 為止,我們已經通過EasyUI完成了貨物信息管理的前端與後臺功能。現在... ...


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封裝。

 

 

 


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

-Advertisement-
Play Games
更多相關文章
  • public void WriteLog(string strLog) { string sFilePath = AppDomain.CurrentDomain.BaseDirectory + "Log"; string sFileName = DateTime.Now.ToString("yyyy ...
  • 在 windows server 2008 r2 版本操作系統上安裝 vs2017 經常出現下載進度條結束後沒有任何反應問題,一般是因為安裝程式相容性造成的,解決方案如下: 將 C:\Program Files (x86)\Microsoft Visual Studio\Installer\vs_i ...
  • .NET和c#: .NET是一個框架,一般稱.net Framework。 c#是一個.NET框架下的編程語言。 縮寫: 程式集: CIL(Common Intermediate Language,公共中間語言):程式集里的執行代碼。其他術語:IL(Intermediate Language)和MS ...
  • #region 添加有效性 DataTable dt = LAbll.LogisticsAccounts(DeptId); //查數據 if (dt.Rows.Count < 20) //有效性字元限制255,一組字元12加分割符=13 { string[] strs = {}; for (int ...
  • 在日常開發過程中,難免有這樣一種需求:就是你所建的每一個類文件或者介面文件都需要標註下作者姓名以及類的用途。如果我們每次創建文件的時候都需要寫一遍這些信息是很煩神的。還好Visual Studio給我們提供了模板註釋的功能來自動幫我們生成類似的註釋代碼。今天趁著中午休息的時間就讓我們一起來操作下吧。 ...
  • 上節中,我們初步的介紹了一下NetCore的一些基礎知識,為了控制篇幅(其實也是因為偷懶),我將NetCore 基礎分為兩部分來寫。 0.WebAPI 項目的建立 1..NetCore 項目執行(載入)過程 2.中間件的執行過程 3.WebAPI 的路由 4.依賴註入 5.非同步編程 上一節中,我把0 ...
  • 這是我在面試過程中遇到的一個小測試,很可惜,當天未能圓滿完成,雖然第二天經過實際測試已經OK 了,但學無止境,繼續努力吧,特將此代碼貼在這裡,供以後學習使用; 窗體界面如下: ...
  • 該轉換器是印度開發團隊推出的,推出時間也挺長,僅支持C#和VB.net代碼轉換。代碼轉換地址: C# -> VB.NET http://www.dotnetspider.com/convert/Csharp-To-Vb.aspx VB.NET -> C# http://www.dotnetspide ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...