BitAdminCore框架應用篇:(二)創建一個簡單的增刪改查模塊

来源:https://www.cnblogs.com/chenyinxin/archive/2018/05/19/9061013.html
-Advertisement-
Play Games

NET Core應用框架之BitAdminCore框架應用篇系列 一、簡介 增刪查改是管理程式最基礎的模式,以下介紹BitAdminCore是如何用最快的效率創建一個模塊。 二、建表 第一件事就是建表,本示例提供最簡單表結構,複雜的功能會在後續一步步釋放。 三、生成實體 1、生成實體之前項目要保證編 ...


 

NET Core應用框架之BitAdminCore框架應用篇系列

 

 

一、簡介


增刪查改是管理程式最基礎的模式,以下介紹BitAdminCore是如何用最快的效率創建一個模塊。

 

二、建表


第一件事就是建表,本示例提供最簡單表結構,複雜的功能會在後續一步步釋放。

 

三、生成實體


1、生成實體之前項目要保證編譯成功。

 

 

2、在程式包控制如中執行命令,資料庫值自己改。

Scaffold-DbContext “data source=.;initial catalog=BitAdminCore;user id=sa;password=123456;” Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models -Context DataContext -Force

 

 

 3、修改連接串


 

 

 

 

 

 4、編譯,再次成功生成。

 

 四、編寫後端API


1、創建controller

2、參考"頁面操作"模塊,進行實現。主要是把代碼拷過來改下就行。

 

 

 代碼如下,自己簡單讀一下

namespace BitAdminCoreOne.Controllers
{
    public class DemoOneController:Controller
    {

        DataContext dbContext = new DataContext();
        /// <summary>
        /// 獲取頁面操作數據
        /// </summary>
        /// <returns></returns>
        public JsonResult QueryDemoOneData(int offset, int limit)
        {
            try
            {
                var list = dbContext.Set<DemoOne>().OrderBy(a => a.CreateTime).Skip(offset).Take(limit).ToList();
                return Json(new { Code = 0, Total = dbContext.Set<DemoOne>().Count(), Data = list });
            }
            catch (Exception ex)
            {
                LogHelper.SaveLog(ex);
                return Json(new { Code = 1, Msg = "伺服器異常,請聯繫管理員!" });
            }
        }

        /// <summary>
        /// 保存頁面操作(新增、修改)
        /// </summary>
        /// <returns></returns>
        public JsonResult SaveDemoOneData(Guid? id)
        {
            try
            {
                //標識唯一性驗證
                var smodel = dbContext.Set<DemoOne>().FirstOrDefault(so =>  so.Id != id);
                if (smodel != null)
                    return Json(new { Code = 1, Msg = "該標識已存在!" });

                DemoOne model = dbContext.Set<DemoOne>().FirstOrDefault(so => so.Id == id);
                if (model == null)
                {
                    model = new DemoOne();
                    this.ToModel(model);
                    model.Id = Guid.NewGuid();
                    model.CreateUserId = SSOClient.UserId;
                    model.CreateTime = DateTime.Now;
                    dbContext.Set<DemoOne>().Add(model);
                }
                else
                {
                    this.ToModel(model);
                }

                dbContext.SaveChanges();
                return Json(new { Code = 0, Msg = "保存成功!" });

            }
            catch (Exception ex)
            {
                LogHelper.SaveLog(ex);
                return Json(new { Code = 1, Msg = "伺服器異常,請聯繫管理員!" });
            }
        }

        /// <summary>
        /// 載入頁面操作數據
        /// </summary>
        /// <returns></returns>
        public JsonResult LoadDemoOneData(Guid id)
        {
            try
            {
                var model = dbContext.Set<DemoOne>().FirstOrDefault(so => so.Id == id);
                return Json(new { Code = 0, Data = model });
            }
            catch (Exception ex)
            {
                LogHelper.SaveLog(ex);
                return Json(new { Code = 1, Msg = "伺服器異常,請聯繫管理員!" });
            }
        }

        /// <summary>
        /// 刪除頁面操作
        /// </summary>
        /// <returns></returns>
        public JsonResult DeleteDemoOneData(string IDs)
        {
            try
            {
                var result = SqlHelper.ExecuteSql(QuerySuite.DeleteSql(IDs, "DemoOne", "id"));
                return Json(new { Code = 0, Msg = "刪除成功!" });
            }
            catch (Exception ex)
            {
                LogHelper.SaveLog(ex);
                return Json(new { Code = 1, Msg = "伺服器異常,請聯繫管理員!" });
            }
        }
    }
}

 

五、添加菜單


  

 

 

 

六、添加前端頁面


 

 

 

 七、修改前端頁面內容


 BitAdminCore做增刪查改使用的是一套自主研發的套件,後續會一一介紹 ,以下是增刪改查的前端代碼,自己感受一下就知道了。

 

 

 

<div class="box">
    <div class="box-body querySuite-wrapper">
        <!-- 按鈕 查詢 導入 -->
        <div class="querySuite-button">
            <button class="btn btn-default" action="query">
                <span class="glyphicon glyphicon-search"></span> 查詢
            </button>
            <button class="btn btn-default" action="add" action-modal="myModal">
                <span class="glyphicon glyphicon-plus-sign"></span> 添加
            </button>
            <button class="btn btn-danger" action="delete">
                <span class="glyphicon glyphicon-trash"></span> 刪除
            </button>
        </div>
        <!-- 列表-->
        <div class="querySuite-table"
             data-key="id"
             data-query-url="../../DemoOne/QueryDemoOneData"
             data-delete-url="../../DemoOne/DeleteDemoOneData">
            <table>
                <thead>
                    <tr>
                        <th style="width:30px;"><input type="checkbox" /></th>
                        <th data-field="name" data-format="edit">名稱</th>
                        <th data-field="createTime" data-format="time">創建時間</th>
                    </tr>
                </thead>
            </table>
        </div>
        <!-- 分頁 -->
        <div class="querySuite-paging"></div>
    </div>
</div>
<!-- 模態框(Modal)編輯數據字典信息 -->
<div id="myModal" class="modal fade formSuite-wrapper" role="dialog" aria-hidden="true">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-body">
                <form data-title="頁面操作"
                      data-save-url="../../DemoOne/SaveDemoOneData"
                      data-load-url="../../DemoOne/LoadDemoOneData">
                    <table>
                        <tr>
                            <th>名稱:</th>
                            <td>
                                <input type="hidden" name="id" />
                                <input type="text" name="Name" required class="form-control" />
                            </td>
                        </tr>
                    </table>
                </form>
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-primary" id="btnSave" action="save">
                    <span class="glyphicon glyphicon-saved"></span> 保存
                </button>
                <button type="button" class="btn btn-default" data-dismiss="modal">
                    <span class="glyphicon glyphicon-remove"></span> 關閉
                </button>
            </div>
        </div><!-- /.modal-content -->
    </div><!-- /.modal -->
</div>

<script type="text/javascript">
    $(function () {
        //查詢套件初始化
        var querySuite = $(".querySuite-wrapper").querySuite().sortable(function (ids) { querySuite.query(); }).query();

        //表單套件初始化
        var formSuite = $("#myModal").formSuite()
            .add(function () {//點擊添加:初始化表單後
            })
            .edit(function () {//點擊編輯:載入數據後
            })
            .submit(function () {//點擊保存:數據保存成功後
                querySuite.query();
            });
    });


</script>

 

 

 八、運行,查看效果


  

九、總結


 

1、極少的代碼便能完成一個增刪查改的功能。

2、還有強大的擴展功能,大家慢慢探索。

 


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

-Advertisement-
Play Games
更多相關文章
  • Matlab學習筆記一、 Desktop Basics (Matlab 基礎知識)當你打開Matlab的時候,matlab按照以下預設的方式展示出來。該桌面主要包括以下幾部分內容:當前文件夾:當前文件夾下麵的文件命令視窗:在該視窗輸入命令,提示符為>>工作區:顯示所有用戶輸入和創建的變數名字以及內容... ...
  • HTTPS(HTTP over SSL)是以安全為目標的 HTTP 通道,可以理解為 HTTP + SSL/TLS,即在 HTTP 下加入 SSL/TLS 層作為安全基礎。其中 TLS 的前身是 SSL,目前廣泛使用的是 TLS 1.2。本文主要針對 TLS 在 HTTPS 中對性能影響的對應調優方... ...
  • Description 菲菲和牛牛在一塊n行m列的棋盤上下棋,菲菲執黑棋先手,牛牛執白棋後手。棋局開始時,棋盤上沒有任何棋子, 兩人輪流在格子上落子,直到填滿棋盤時結束。落子的規則是:一個格子可以落子當且僅當這個格子內沒有棋子且 這個格子的左側及上方的所有格子內都有棋子。 棋盤的每個格子上,都寫有兩 ...
  • Java集合類的詳解與應用 集合簡介: 1.定義:可以同時存儲不同類型的數據 他的存儲空間會隨著數據的增大而增大 2.缺點:只能存儲引用數據類型 3.優點:更加合理的利用空間,封裝了更多的方法,用起來更加方便 4.分類:集合分為:Collection(介面): List介面:ArrayList類,L ...
  • 圖論是演算法競賽的一大板塊,二分圖又是其中一個重要的特殊模型——好像有點像網路流QwQ 例題:eXam(SGU 172)、The Perfect Stall(POJ 1274)、Machine Schedule(POJ 1325) ...
  • BitAdminCore是基於NET Core2.0的後端快速開發框架,本篇主要目標是介紹如何使用框架開發應用。框架的一些特性等。 系列鏈接 BitAdminCore框架應用篇:(一)使用Cookiecutter創建應用項目 BitAdminCore框架應用篇:(二)創建一個簡單的增刪改查模塊 ...
  • 64位的access一定要用64的程式才能正確打開,仍然用"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=Test.accdb;Persist Security Info=False"即可。 ...
  • 連接字元串是這樣的:connectionString="server=IP地址;database=資料庫名稱;uid=sa;pwd=123456;" 並不是利用mdf文件連接:connectionString="Data Source=.\SQLEXPRESS;AttachDbFilename= |... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...