在Bootstrap開發框架的工作流模塊中實現流程完成後更新資料狀態處理

来源:https://www.cnblogs.com/wuhuacong/archive/2018/11/15/9962031.html
-Advertisement-
Play Games

在開發查看流程表單明細的時候,在Web界面中,我們往往通過使用@RenderPage實現頁面內容模塊化的隔離,減少複雜度,因此把一些常用的如審批、撤銷、會簽、閱辦等等的流程步驟都放到了通用處理的頁面ViewDetail.cshtml裡面實現了。那麼如果在一些特殊的表單處理過程中,我們在審批完成後需要... ...


在開發查看流程表單明細的時候,在Web界面中,我們往往通過使用@RenderPage實現頁面內容模塊化的隔離,減少複雜度,因此把一些常用的如審批、撤銷、會簽、閱辦等等的流程步驟都放到了通用處理的頁面ViewDetail.cshtml裡面實現了。那麼如果在一些特殊的表單處理過程中,我們在審批完成後需要觸發一個事件來修改一些業務表的數據的處理的話,就會變得麻煩起來,通用的處理就代表要損失一部分靈活性,特殊性。那是否可以通過一些處理,能夠實現這些特殊更新的操作呢?本篇隨筆介紹的就是這個方面,實現流程完成後更新資料狀態處理。

1、頁面的模塊關係

之前我在隨筆《在Bootstrap開發框架的前端視圖中使用@RenderPage實現頁面內容模塊化的隔離,減少複雜度》裡面已經介紹過,對於這種有著共同內容的頁面,我們可以把它提取出來,然後在主頁面裡面使用@RenderPage的方式進行包含進來,這樣有助於我們模塊化的處理。

上面通用的處理內容,全部在Apply/ViewDetail.cshtml頁面裡面。

它的頁面內容,主要是封裝一些常規的界面和處理腳本。

也就是對於一些如資產領用或者資產處置的界面,它都是包含這些基礎流程顯示的界面和處理邏輯的。

查看具體流程表單明細的界面如下所示。

 

或者資產領用表單的查看界面如下所示。

 

2、腳本的模板化處理,實現子類函數的差異性

在查看信息的頂部有對應的流程處理按鈕,如果用戶是流程參與人,那麼可以執行相關的處理。

審批是一個通用的常規處理操作,彈出界面需要錄入處理意見,以及下一步流程的處理人員,如下界面所示。

既然我們需要在一些業務表單結束後,觸發一些後處理的事件來實現我們所需要數據的更新操作,那麼我們可以通過使用Javascript的模板化方法的設計模式來實現我們需要的處理。

首先我們在通用處理的模塊頁面裡面,定義好我們需要的函數,可以保留它不做任何事情,僅僅定義一個空殼函數就可以,不過需要在調用它的地方加上這個函數即可,而差異處理的不同,則讓子類頁面重載它的函數就可以實現差異性的模板方法模式。

例如我們在Apply/ViewDetail.cshtml頁面,這個通用頁面是相當於基類界面了,定義它的函數處理如下所示。

    //審批處理後的執行操作
    //該操作一般發生在申請單完成後,需要修改業務表單數據的情況
    //該函數預設為空,具體邏輯給子視圖頁面ViewDetail.cs裡面實現
    function ToCompletedForm() {
        console.log("ToCompletedForm");//留待子類重寫函數
    }

而在可能需要進行後續處理的地方,調用這個方法,以完成它的調用邏輯。

以上就是處理流程的時候,增加上這個函數處理方法的調用,其他地方如果是類似的場景,則類似處理即可。

然後,我們不同的子類頁面,重寫好自己的處理函數就可以覆蓋基類的函數ToCompletedForm的處理邏輯了。

以上是資產領用流程的一個處理步驟,其中主要就是在流程結束的時候,完成一些數據更新和狀態的處理操作。

以上就是對於表單完成後的一些特殊處理的實現方法,在流程結束的時刻,我們可以做更多的相關後臺處理邏輯,都可以這樣統一在一個後臺方法中處理。

這樣通過這種方式實現的邏輯,不影響頁面的關係和處理過程,僅僅是我們在子頁面裡面重寫一下處理規則即可,如果不需要,也可以不重寫,不影響整個處理過程。 


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

-Advertisement-
Play Games
更多相關文章
  • 將word2中的內容插入到word1中的指定位置(經測試可用) 在官網找到的例子,記錄一下: ...
  • 一、自定義泛型方法(Generic Method),將類型參數用作參數列表或返回值的類型: 1.聲明泛型方法時,可以在參數列表中使用這個類型參數:void MyFunc<T>(T obj) { };此時在調用該泛型方法時可以省略類型參數的指定由編譯器推斷其類型,例如:MyFunc<int>(myNu ...
  • 講人:大石頭 時間:2018-11-14 晚上20:00 地點:釘釘群(組織代碼BKMV7685)QQ群:1600800 內容:魔方Newlife.Cube許可權系統的使用及模版覆蓋詳解 準備 源碼地址: https://github.com/NewLifeX/NewLife.Cube 演示地址:ht ...
  • 2018-11-15 $(document).keydown(function (event) { if (event.keyCode == 13) { $("#LoginBtn").click(); } }); $("#LoginBtn")是登陸按鈕 ...
  • .NET ThreadPool 最大線程數的限制 IIS併發瓶頸,有幾個地方,IIS線程池的最大隊列數,工作進程數,最大併發數。這些這裡就不展開。主要是最近因為過度使用Task 導致的線程數占用過多,所以實驗了一下 .net線程池 的限制,分享一下。 註意IIS線程池與.NET線程池不是同一個東西, ...
  • 問題:伺服器未提供有意義的回覆;這可能是由協定不匹配、會話過早關閉或內部伺服器錯誤引起的。 另類的解決辦法,如果實在沒有思路,不妨把代碼還原一下,然後把更改的內容在重新添加一遍,或許問題就解決了。 ...
  • 背景        最近需要將一些外部的 及其他 介面的調用移到一個獨立的 項目中,然後供其他 項目調用。之前的幾個 已經成功遷移,但是在遷移一個需要用戶名密碼認證的 介面的時候卻始終調用不成功。下麵直接上代碼。 示例代碼 在 中 ...
  • 很多時候我們做網站時單純的用bootstrap等前端框架實現的前端自適應帶給用戶的體驗並不太好,所以為了提高用戶體驗會專門針對PC端網頁重新設計一套移動端網頁,但是怎麼才能做到在移動端訪問PC頁面的時候返回對應的移動端頁面,而不是PC端頁面呢?下麵我們就簡單的進行介紹。主要技術是asp.net co ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...