abp(net core)+easyui+efcore實現倉儲管理系統——ABP WebAPI與EasyUI結合增刪改查之六(三十二)

abp(net core)+easyui+efcore實現倉儲管理系統目錄

abp(net core)+easyui+efcore實現倉儲管理系統——建立應用服務(五)html

abp(net core)+easyui+efcore實現倉儲管理系統——EasyUI前端頁面框架 (十八) 前端

 

   在上一篇文章 abp(net core)+easyui+efcore實現倉儲管理系統——ABP WebAPI與EasyUI結合增刪改查之五(三十一) 中咱們實現了新增組織部門信息功能,不過還存在一些BUG。今天咱們來繼續完善組織部門信息新增功能,並進行測試。數據庫

 

11、加載異常解決

    1.在「添加組織信息」界面中輸入相應的組織信息以後,點擊「保存」按鈕 。在彈出的確認對話框中點擊「肯定」按鈕。在保存成功以後,並且數據庫中的記錄正好超過了10條,在進行樹列表初始化時,數據沒法顯示。以下圖。 json

     2.在「組織信息」列表界面中使用鼠標點擊「添加」按鈕,彈出「添加組織信息」界面,咱們使用鼠標點擊「上級組織」,沒法顯示任何數據。以下圖。瀏覽器

 

      3. Visual Studio 2017的按F5運行,同時在「ABP.TPLMS.Web.Mvc」項目的Controller目錄中找到OrgsController.cs文件,在GetJsonTree中設置斷點。以下圖。咱們發現classlist對象中只有10條數據,而實際上咱們有12條數據。是否是因爲這個緣由形成的呢?框架

 

 

     4. 咱們來看一下PagedOrgResultRequestDto對象paged,發現paged的屬性MaxResultCount=10,以下圖。Paged實例默認最多查詢10條記錄。測試

     5. Visual Studio 2017的「ABP.TPLMS.Web.Mvc」項目的Controller目錄中找到OrgsController.cs文件,代碼中添加最大查詢記錄數。代碼修改以下: ui

using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Abp.AspNetCore.Mvc.Authorization; using Abp.Web.Models; using ABP.TPLMS.Controllers; using ABP.TPLMS.Orgs; using ABP.TPLMS.Orgs.Dto; using ABP.TPLMS.Web.Models.Orgs; using Microsoft.AspNetCore.Mvc; // For more information on enabling MVC for empty projects, visit https://go.microsoft.com/fwlink/?LinkID=397860 

namespace ABP.TPLMS.Web.Controllers { [AbpMvcAuthorize] public class OrgsController : TPLMSControllerBase { private readonly IOrgAppService _orgAppService; private const int MAX_COUNT= 1000; public OrgsController(IOrgAppService orgAppService) { _orgAppService = orgAppService; } [HttpGet] // GET: /<controller>/

        public IActionResult Index() { return View(); } [DontWrapResult] [HttpPost] public string List() { PagedOrgResultRequestDto paged = new PagedOrgResultRequestDto(); paged.MaxResultCount = MAX_COUNT; var userList = _orgAppService.GetAll(paged).GetAwaiter().GetResult().Items; int total = userList.Count; var json = JsonEasyUI(userList, total); return json; } [DontWrapResult] [HttpGet] public JsonResult GetJsonTree() { PagedOrgResultRequestDto paged = new PagedOrgResultRequestDto(); paged.MaxResultCount = MAX_COUNT; var classlist = _orgAppService.GetAll(paged).GetAwaiter().GetResult().Items; List<TreeJsonViewModel> list = LinqJsonTree(classlist,0); return Json(list); } /// <summary>
        /// 遞歸 /// </summary>
        /// <param name="list"></param>
        /// <returns></returns>
        // 
        private List<TreeJsonViewModel> LinqJsonTree(IReadOnlyList<OrgDto> orgs,int parentId) { List<TreeJsonViewModel> jsonData = new List<TreeJsonViewModel>(); List<OrgDto> classlist = orgs.Where(m => m.ParentId == parentId).ToList(); classlist.ToList().ForEach(item => { jsonData.Add(new TreeJsonViewModel { id = item.Id, children = LinqJsonTree(orgs, item.Id), parentId = item.ParentId, text = item.Name, url = string.Empty, state = parentId == 0 ? "open" : "" }); }); return jsonData; } } }
    6.在Visual Studio 2017的解決方案資源管理器中,按F5運行應用程序。

     7.在瀏覽器中的地址欄中輸入「http://localhost:5000/」,而後輸入管理員用戶名進行登陸。url

     8.在主界面的菜單中,選擇「Business->組織管理」菜單項,瀏覽器中呈現一個組織信息列表與四個按鈕。組織信息能正常顯示。以下圖。spa

 

      9.在「組織管理」列表頁面中使用鼠標點擊「添加」按鈕,彈出「添加組織信息」界面。以下圖。

 

 

 

十二、測試新增組織信息

     1.在Visual Studio 2017的解決方案資源管理器中,按F5運行應用程序。

     2.在瀏覽器中的地址欄中輸入「http://localhost:5000/」,而後輸入管理員用戶名進行登陸。

     3.在主界面的菜單中,選擇「Business->組織管理」菜單項,瀏覽器中呈現一個組織信息列表與四個按鈕。以下圖。關於菜單的生成能夠參見文章(

abp(net core)+easyui+efcore實現倉儲管理系統——菜單-上 (十六)     、abp(net core)+easyui+efcore實現倉儲管理系統——菜單-下(十七)  )。

 

 

     4.新增組織:點擊「添加」按鈕,彈出一個「添加組織信息」的操做界面,以下圖中所示。

     5.在輸入相應的貨物信息以後,點擊「保存」按鈕 。在彈出的確認對話框中點擊「肯定」按鈕。在彈出的「保存成功」確認對話框中點擊「肯定」按鈕。以下圖。

 

       6.彈出保存成功。見下圖。

 

 

 

 

 
 

 

原文出處:https://www.cnblogs.com/chillsrc/p/12116075.html

相關文章
相關標籤/搜索