三、敏捷開發框架-查詢頁面模型-QueryPage 再認識

来源:https://www.cnblogs.com/godmodel/archive/2020/06/02/13029086.html
-Advertisement-
Play Games

在複雜的頁面看看清問題的本質: 下麵的頁面,我說其實一部分是編輯頁面 好吧,我們一起來找到這個編輯頁面 我們通過實例來進一步分析 這個頁面是,用戶列表或者用戶編輯畫中點擊用戶【設置角色】彈出來的功能頁面 左側是待選擇的角色信息,右側是已經分配給 用戶的 角色信息 界面效果如下: 前面我們瞭解了兩個非 ...


在複雜的頁面看看清問題的本質:

下麵的頁面,我說其實一部分是編輯頁面

 

好吧,我們一起來找到這個編輯頁面

 

我們通過實例來進一步分析

這個頁面是,用戶列表或者用戶編輯畫中點擊用戶【設置角色】彈出來的功能頁面

左側是待選擇的角色信息,右側是已經分配給 用戶的 角色信息

 

界面效果如下:

image.png

前面我們瞭解了兩個非常常用的頁面模型  查詢頁面模型、編輯頁面模型

這是什麼頁面模型,難道是第三個頁面模型,左右選擇頁面模型,穿梭頁面模型

哪來那麼多頁面模型,如果頁面模型太泛濫,都是模型,就都不是模型了。

 

把上面的截圖一半

image.png

很熟悉,

這不就是查詢頁面嗎?

右側也截圖下:

image.png

好像也是查詢頁面,不過只是缺少個查詢按鈕而已

 

按照前面的學習,實現這樣一個查詢頁面是不是很容易的事情嘛

 

先看視圖結構

image.png

 

隱藏域:UserId 用來存儲當前對哪個用戶進行設置的,這是URL參數傳過來的

編輯區 分 left 中間功能按鈕區  right

 

展開看看,

left 的確就是一個查詢頁面的結構

    標題、查詢條件form、查詢按鈕、查詢表格

image.png

 

兩個查詢頁面模型的實現

image.png

兩個查詢,本質上都是查詢 role 所以api都是調用 roleSearch API 只是增加類別的區分

pageLeft 查詢 未綁定 用戶的 角色

pageRight查詢 已綁定用戶的角色

 

image.png

頁面配置了 search:true  打開頁面立即查詢

這樣查詢功能就都實現了。

下麵就來分析下其它功能的開發,在開發之前我們要套模式,為什麼要套用前面介紹的

ECIAction動作模型,因為通過前面的介紹,發現已有的模型能夠以簡單不到不能簡單的代碼實現功能

既然如此,那麼我們就要對我們的所有開發功能就行歸類思考。以期用高效的行之有效的模式解決問題

 

回顧下,第一個課的畫面

image.png

紅色框內的操作模式,          我們定義為  行內 操作模型   操作對象是 當前行的主鍵

藍色框內的操作模式,          我們定義為  批量 操作模型 (對錶格控制項的批量)操作對象是選擇的多筆主鍵

還有就是 編輯頁面上的 按鈕 我們定義為  編輯 操作模型   操作對象是當前編輯的主鍵

 

 

有了上述的三種EciAction模型作為操作行為的基礎,我們要來解構我們新任務下的操作行為

image.png

如上圖:

左右紅色按鈕是 行內操作模型

中間藍色按鈕   其實是批量操作模型,不過是按鈕的擺放位置,放到了頁面中間而已。

【添加角色】操作的對象是左側的列表

【移除角色】操作的對象是右側的列表

這樣來看,是不是就容易實現了。

 

我們先來看

image.png

 

image.png

左側操作模板列 增加 【添加角色】按鈕 調用方法 addRole

image.png

這是一個行內操作模型

解釋下代碼,調用後臺 UserAddRole API  通過Action模型,自動幫我們將 當前行上的 RoleId 傳遞到後臺

在我們這個場景中,是對用戶增加角色,所以請求API的時候需要傳遞上 UserId

這個是任何操作模型都抽象不了的,抽象不了的東西就交個業務去實現,通過在調用Execute之前調用prepare方法

意思是準備,準備後再調用。

 

image.png

現在執行完畢之後,需要將左側和右側的列表都重新查詢一下,那就通過then函數註入 request 的onSuccess 方法接管處理過程

 

下麵來實現【添加角色】

image.png

 

DOM:

image.png

 

先歸類,這是一個 批量動作模型 

 

image.png
代碼和上面是一樣,就是mode改成 batch 意思是批量動作模型

這樣是不是實現非常容易

 

同時看下右側的【移除角色】的代碼

image.png

和上面的代碼,除了API的差別外,就是 操作的目標對象是 pageRight

 

 

下麵來實現【設置機構】

image.png

 

image.png

 

至此功能,大體都實現了

這是我們一起好好審視下右側

image.png

右側我們看到的是也是一個查詢模型

有表格,紅色框線部分隱含一個 查詢form,預設條件是 頁面傳過來的 USERID

那麼上面,藍色框線部分 算啥。

看看用戶編輯:

image.png

image.png

上面是用戶編輯

 

看下麵的地址 

image.png

傳入的也是 UserId

 

image.png

拋開所有的干擾項

我們只看到這塊畫面 其實這就是一個編輯頁面模型,不過編輯顯示的內容比較少,沒有了保存、新增按鈕

但是要看清本質。找到對應的 頁面模型。

那麼代碼就好實現了。

image.png

那麼分析透徹了之後,實現只需要兩行代碼

想要一行也行

image.png

到此,這個相對複雜一點的畫面也實現了

 

文章開頭說的,編輯頁面找到了

不是純粹為了找到編輯頁面,

而是看清問題的本質,發現它其實就是編輯頁面模型,用編輯頁面模型的代碼解決問題

 

經過我們的分解,其實是兩個查詢頁面模型+編輯模型的組合

 

後面我們會繼續看,是否大部分的頁面開發就用我們抽象的 幾個頁面模型 就能解決所有問題。拭目以待。


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

-Advertisement-
Play Games
更多相關文章
  • Named pipe (more flexible)Allows two-way communication between arbitrary processes on the same computer or different computers across a network.A pipe ...
  • BackWork代碼: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace Utils { publ ...
  • 系列文章 基於 abp vNext 和 .NET Core 開發博客項目 - 使用 abp cli 搭建項目 基於 abp vNext 和 .NET Core 開發博客項目 - 給項目瘦身,讓它跑起來 基於 abp vNext 和 .NET Core 開發博客項目 - 完善與美化,Swagger登場 ...
  • 很多情況下,我們需要用到Tab 選項卡的情況 例如下麵 註冊審批頁面 這個場景是,註冊審批,包含兩部分,一個是對註冊組織機構的審批,一個是註冊用戶的審批那麼這個需要用個Tab選項卡來實現比較合適,而不是弄兩個功能菜單 那這個頁面怎麼實現呢。 關於Tab的使用,我們有兩種模式。 第一種模式:Tab只是 ...
  • serilog .net core 3.1 配置方式 安裝包dotnet add package Serilog dotnet add package Serilog.AspNetCore 早初始化模式 public class Program { public static IConfigurat ...
  • 1、給定一個int數組,編寫方法以統計所有偶數的值。 有很多方法可以做到這一點,但是最直接的兩種方法是: static long TotalAllEvenNumbers(int[] intArray) { return intArray.Where(i => i % 2 == 0).Sum(i => ...
  • 通過前面的學習我們應該熟練掌握了 QueryPage 查詢頁面模型 EditPage 編輯頁面模型 同時也掌握了,並不是一個頁面就只能是一個模型,可以是組合使用的情況 可以是 查詢+編輯的組合 也開是 查詢+查詢的組合 難道我們只有這兩種頁面模型嗎? 今天我們一起來學習我們開發中遇到的第三種頁面模型 ...
  • 敏捷開發框架初識組件式開發 可能這個叫法一定非常準確,但是的確實現了組件式的開發 那好吧,姑且就這麼叫吧 下麵講講這個頁面的由來: 首先我們提供了一個功能檢索的頁面,用於查詢所有的功能菜單 這個頁面的實現,QueryPage 太拿手了 查詢列表的所有功能全部搞定 點擊【編輯】或者雙擊進入編輯畫面 這 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...