敏捷開發框架-EciTab選項卡控制項設計

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

在項目的實際開發過程中,我們經常會遇到Tab頁面的開發 EciTab控制項有多種使用方式: 下麵介紹Frame容器方式: 下麵介紹的Tab頁面採用的策略是 Tab頁面管理幾個子頁面,頁面組織上用Iframe管理的模式 採用Iframe的原因主要有兩個 1.開發簡單,每一個頁面都是簡單的畫面 2.性能考 ...


在項目的實際開發過程中,我們經常會遇到Tab頁面的開發

 

EciTab控制項有多種使用方式:

 

下麵介紹Frame容器方式:

 

下麵介紹的Tab頁面採用的策略是 Tab頁面管理幾個子頁面,頁面組織上用Iframe管理的模式

採用Iframe的原因主要有兩個

1.開發簡單,每一個頁面都是簡單的畫面

2.性能考慮,打開一個複雜的Tab頁面,不見得所有Tab都會點擊,這時候可以採用選項卡懶載入的方式

                     沒有點擊的選項卡可以DOM都不載入。

 

 下麵介紹,從列表頁面進入到EditTab頁面的過程,一起來分析Tab頁面需要寫的代碼

 

 

 

如上圖,列表頁,Tab 管理頁   (管理了兩個頁面  EnterpriseEdit 企業編輯頁,EnterpriseInvoice 企業開票抬頭信息列表頁)

從列表頁面,有兩種方式進入 Tab頁面

1.新增

2.點擊行內已有數據進入(也就是編輯)

我們一起來看下 Tab頁面的源代碼

Tab組件,設計了兩個選項卡  head  kpInfo

分別對應企業信息維護畫面、企業開票抬頭列表畫面

實際上 上面的URL和 lazyURL寫上去都是沒有意義的,因為實際情況遠沒有這麼簡單,需要應對變化的過程。

分析一下到底有哪些變化:

進入這個Tab頁面的兩種方式:

新增方式:表現來看,沒有傳入主鍵

編輯方式:表現來看  就是傳入了 列表頁面上選中行的主鍵值 id=xxxx

 

如果傳入主鍵:那需要將主鍵值傳遞到 兩個頁面

 

 

 上面的代碼是關於URL的設置,需要考慮的不同情況:

 如果沒有傳入主鍵值:第二個TabIItem設置lazyURL都是沒有意義的,headId是子表和主表之間的關聯鍵,id都不存在,所以就不可能去設置URL屬性

 實際上不僅僅關於地址的問題,如果是新增,那麼還要控制第二個Tab不能點擊,代碼如下

好,如上就是進入Tab頁面的相關初始化代碼。

 

那繼續分析,還有什麼變化:

當前Tab是新增的時候,我們在編輯頁面,錄入了相關值,點擊了保存,這時候就等於產生了主鍵。

這是頁面狀態其實發生了變化,這個時候其實編輯狀態了。

既然是編輯狀態,那麼第二個Tab這個時候需要能點擊,同時需要設置成正確的地址

相關的代碼如下(紅色框線部分):

 

    這是變化之一:那麼我們繼續點擊新增呢。這個時候頁面當前狀態又轉變成新增狀態了。

   新增狀態的特點是,第二個Tab是不能點擊的,頁面地址(暫且不考慮,只要控制好不能點擊即可)

   實現代碼如下:

 

 

如上差不多就是一個Tab頁面標準的處理過程,解決了各種變化的問題。

如果接著後面又加一個Tab,企業信息的操作歷史,那麼我們相關的代碼都要參考第二個Tab的方式寫一下。

 

代碼不是特別複雜,但是必須是面面俱到,缺一不可以。

 

雖然上述代碼我認為已經不複雜。但是我們任然要追求極致,要偷懶,能否近一步簡化代碼開發

上述的過程是否標準過程?

能不能將上述的標準過程封裝成固定的開發範式?

能否簡化?

能不能先不重要。

想不想才是最重要。

你想要怎麼簡化?

既然你都這麼說了,不要怪我要求高。

有什麼要求,儘管提,能否實現那是後話,甭客氣。

對上述變化能否一行代碼都不寫,全部搞定。

你的想法真徹底,一步提到底,不拖拖拉拉, 給你一個100個贊!!!

 

好吧,能不能實現先不管,先享受一下暢享的感覺,這也搞定了、那也搞定了,那該多麼輕鬆啊

 

夢想還是要有的。最壞的情況,當我白說,最好的情況嘛,那就是好極了,不要打擾我,先做夢去!

 

美夢成真,如下圖:紅色框線EAD敏捷開發框架幫你實現你許下的心愿,代碼清零,一行代碼也不寫了。

 

真的嗎?的確沒有代碼了,但是嚴重懷疑前面介紹的各種變化情況,刪代碼容易,但是功能都還在嗎?

到底是怎麼實現的。

框架設計了規則解析機制

{}裡面的內容都是動態內容

{all}表示URL請求的所有參數

{keyValue}是主鍵

{req.xxxx}表示從URL獲取參數xxxx 例如 {req.id }

同時EciTab控制項設置了 keyField屬性,本例中為 ID

 

EciTab控制項在初始化的過程中通過規則解析引擎,動態分析出實際的地址信息。

同時動態的分析出哪些TabItem是依賴於{keyValue}的,也就是主鍵

所有依賴於主鍵的,同時當前頁面 keyValue又是為空的時候,那麼Tab自動設置成不可以點擊模式。

keyValue的變遷過程,可以是從列表頁點擊【編輯】過來的(從URL中獲取,keyField屬性發揮重要作用)。

也可以是一開始,是新增模式(為空)然後編輯頁面【保存】變成有值了的( 這一步是編輯頁面要告訴Tab頁的,編輯頁面的職責

當然了編輯頁面有編輯頁面模型,通過模型設計,讓開發人員在編輯頁面也不需要寫一行代碼

)。

只要相關依賴參數變化了,就會觸發Tab控制項自我管理Tab的表現(目前主要是url和是否可以點擊)

在控制URL的過程中,框架將研發人員一開始寫的URL、LazyURL 作為設計時模板進行緩存

命名為 designURL,目的是在變化發生時,還能找到一開始的原始字元串,否則無法實現動態解析!

 

最後我們的代碼,開發人員只要寫如下,非常簡潔明瞭,剩下的全部交給EAD敏捷開發框架來自動化實現

 

 

再次見面:

這優化,還滿意嗎?

但是我還想提個需求。

還要提需求?我無能為力了,我沒有代碼了,還怎麼改進啊,是吧。

不是,上面的封裝非常棒,全部框架接管,我不用寫任何代碼。封裝的徹底。

就是因為太徹底了,可能會有點擔心,萬一齣現某個極端情況,研發人員需要自己控制tab

之前好歹還有個 var  tab = new EciTab({id:"eciTab"})

我還有個 tab變數,我還能操控。

萬一,怎麼辦?

 

你的擔心我已經收到,已經為大家提供瞭解決方案:

image.png

EciTab控制項,預設有框架全自動初始化。99%的情況下不需要你過多操心。

萬一遇到極端情況,只要設置 init="false"

然後你自己寫代碼:var  tab = new EciTab({id:"eciTab"})

這時候,你就有了對tab的全部掌控許可權了。

通過:自己顯示的寫 new EciTab({id:"eciTab"})這一行代碼,之前說的所有應對變化的功能也全部包含在內。

這下高枕無憂了吧!

 

得寸進尺的人,我又來了。不會煩我吧。

哪裡,我就喜歡你這“得寸進尺”的人,我這裡叫有追求。

好吧

var  tab = new EciTab({id:"eciTab"}) 還要加 init=“false”

好像有20多個字元,不光是20字元的問題,代碼寫在兩個地方。

我嫌煩。

追求的道路上一定不能滿足現狀。

你的煩惱,我來幫你解憂。

eci開發庫是EAD開發框架的功能函數聚集地。

記住有問題 eci來幫忙。

var tab=eci.getTab(id)  給我哪個tab,初始化工作還是交給框架,想要獲取控制項的時候向eci要即可。

 


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

-Advertisement-
Play Games
更多相關文章
  • 上次講了微服務的前世今生(五):CAP 原則與 BASE 理論,這次我們再說微服務架構的前世今生(六):微服務架構帶來的問題。 一、客戶端如何訪問服務? 傳統的開發方式,所有的服務都是本地的,客戶端可以直接調用,現在按功能拆分成獨立的服務,客戶端如何訪問? 後臺有 N 個服務,前臺就需要管理 N 個 ...
  • 我認為,代碼優化的最重要的作用應該是:避免未知的錯誤。在代碼上線運行的過程中,往往會出現很多我們意想不到的錯誤,因為線上環境和開發環境是非常不同的,錯誤定位到最後往往是一個非常小的原因。 ...
  • 【SpringCloud】Gateway 配置全局過濾器獲取請求參數和響應值 實現Ordered介面getOrder()方法,數值越小越靠前執行,記得這一點就OK了。 獲取請求參數RequestBody @Component @Slf4j @AllArgsConstructor public cla ...
  • x 深夜,在東莞,7天酒店,打開電腦,訪問國內最大的同性交友網站。 日常開發中,導出導入場景非常多,尤其是對於後臺管理更是一個列表一個導出,如果從導出的業務中抽離出復用代碼,專註於邏輯開發,對於開發者而言非常重要。前有使用POI,但作者還是更喜EasyExcel的簡潔高效不拖沓,所以特意寫篇文章記錄 ...
  • 前言 ​ 關於 Python 這個欄目,咕了幾個月了,今天講講如何發送驗證碼並驗證。 ​ 因為部分原因,寫這篇文章的時候心情是不太好的,播放首歌吧。 代碼 導入 導入yagmail,random和time庫 import yagmail,random,time #導入 yagmail , rando ...
  • 一.官方文檔 https://pypi.org/project/muggle-ocr/ 二模塊安裝 pip install muggle-ocr # 因模塊過新,阿裡/清華等第三方源可能尚未更新鏡像,因此手動指定使用境外源,為了提高依賴的安裝速度,可預先自行安裝依賴:tensorflow/numpy ...
  • 案例故事: 即時通訊(IM)軟體有很多,比如企業微信,釘釘,飛書,Skype, 微軟的Lync等, 這些軟體現在都很牛,還能監控誰誰在不在電腦旁工作,誰誰誰提前下班溜了。。。 一次偶然的機會,有個妹子請教我,她每天都想準時18點下班, 她問我如何做到: 假裝企業微信線上,併在2個小時後(20點)準時 ...
  • 引用的DLL MySql.Data.MySqlClient System.Data City實體 public class City { public int ID { get; set; } public string Name { get; set; } public string Countr ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...