在項目的實際開發過程當中,咱們常常會遇到Tab頁面的開發緩存
EciTab控件有多種使用方式:框架
下面介紹Frame容器方式:函數
下面介紹的Tab頁面採用的策略是 Tab頁面管理幾個子頁面,頁面組織上用Iframe管理的模式性能
採用Iframe的緣由主要有兩個優化
1.開發簡單,每個頁面都是簡單的畫面url
2.性能考慮,打開一個複雜的Tab頁面,不見得全部Tab都會點擊,這時候能夠採用選項卡懶加載的方式spa
沒有點擊的選項卡能夠DOM都不加載。設計
下面介紹,從列表頁面進入到EditTab頁面的過程,一塊兒來分析Tab頁面須要寫的代碼3d
如上圖,列表頁,Tab 管理頁 (管理了兩個頁面 EnterpriseEdit 企業編輯頁,EnterpriseInvoice 企業開票擡頭信息列表頁)blog
從列表頁面,有兩種方式進入 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變量,我還能操控。
萬一,怎麼辦?
你的擔憂我已經收到,已經爲你們提供瞭解決方案:
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要便可。