作者:京東物流 柳宏
•目前的線路配載前端基於zTree+FixedHeaderTable+JQuery實現,通過zTree監聽節點被選中和取消選中,計算該操作後是否觸發節點的合併或展開,進而重新渲染配載列表中的資料
線路X
生效時間 失效時間
2022-11-02 2023-01-25
A(父節點):包含A1、A2、A3三個子節點,當前只存在A1的配載如下:
生效時間 失效時間 班期
A1 2022-11-02 2099-12-31 12
參考日期為11.17日,此時勾選A2+A3後觸發A的合併,此時配載列表展示A節點
生效時間 失效時間 班期
A 2022-11-02 2023-01-25 1234567
生效時間 失效時間 班期
A1 2022-11-02 2022-11-16 12
A 2022-11-17 2023-01-25 1234567
A(父節點):包含A1、A2、A3三個子節點,其中任意節點的班期不一致都無法合併
1)如果 原始生效日期小於合併後父節點的生效日期,則切斷 原始生效日期 ~ 父節點的生效日期-1天(相當於保留切斷前的生效日期那一段)
2)如果 原始失效日期大於合併後父節點的失效日期,則切斷 父節點的失效日期+1 ~ 原始失效日期 (相當於保留切斷前的失效日期那一段)
1. 配載A的原始生失效時間為 20221103 - 20221110
2. 配載A在經過同級子節點合併後,生失效時間為 20221105-20221108
3. 那麼對於配載A來說,在合併後仍然需要保留兩段配載記錄
3.1 生失效時間為 20221103-20221104
3.2 生失效時間為 20221109-20221110
•採用所見即所的方式儲存資料,使用者在前端完成切斷操作後,儲存到資料庫的記錄與前端展示一致
zTree:配載樹
treeNode:配載樹中的節點
nodeId:節點id
childrenNodes:包含當前節點的所有子節點集合
stowageList:配載列表的Dom結構
originStowageMapTI:原始配載:{key:節點;value:配載資料的dom結構}
newStowageMapTI:新增節點配載:{key:節點id;value:節點}
stowageFrequencyMap:配載節點和班期關係:{key:節點id;value:班期}
stowageTimeMap:配載節點和生失效日期關係:{key:節點id;value:[生效時間,失效時間]}
frequencyTreeMap:班期和節點的關係:{key:班期;value:節點陣列}
node.pid:節點的父id
node.id:節點的id
在配載樹上監聽事件,當觸發選中/取消選中時,遞迴的獲取childrenNodes
維護配載與班期、配載與生失效日期的關係
將已有配載列表中的資料維護到stowageFrequencyMap、stowageTimeMap、originStowageMapTI中
1)如果當前節點非禁用 && 勾選 執行 合併邏輯;否則遞迴遍歷節點;最終返回結果集
2)如果當前節點非半選 && 非父節點,向父節點中查詢班期,維護節點屬性,加入結果集並返回
3)根據節點的pid查詢stowageFrequencyMap中是否存在班期
配載樹中的網點關係主要是四級,舉例說明 C(快遞全國) 下面某些節點的level 與 pid 的關係
level=1
pid:C 表示全國
level=2
pid:C-10 表示華南
level=3
pid:C-10-16 表示福建
level=4
pid:C-10-16-1303 表示泉州
演演算法邏輯:根據pid擷取相應的字串為key,查詢是否存在父節點的班期
1.如果是父節點則遍歷,按照每個子節點去stowageFrequencyMap中獲取班期,分為兩種情況如下;找到班期後維護frequencyTreeMap,將同班期的節點維護到list中儲存,即形成 班期-節點list的資料結構
2.向父節點中獲取班期,同上
3.向子節點中遞迴獲取班期,並將結果儲存到新的資料結構frequencyChildMap中,然後合併到frequencyTreeMap中
對frequencyTreeMap集合進行判斷,如果數量為1表示 與該節點同級的節點班期相同,觸發了合併,將節點加入結果集返回;否則說明當前節點的同級節點存在不同班期,不能進行節點向上合併,直接遍歷frequencyTreeMap中的value集合,加入結果集返回
對於觸發了合併的結果集 frequencyTreeMap 中的每個節點遍歷 同 當前線路的生失效日期比較,取出同級節點中的最大生效時間,最小失效時間,作為該同級節點中的最大公共時間範圍設定到每個節點屬性中
定義變數
1. queryTime:參考日期
2. maxDisableTime:最大失效時間
3. enableTime:線路生效時間
4. disableTime:線路失效時間
5. originEnableTime:記錄原始生效時間
6. originDisableTime:記錄原始失效時間
7. newDisableTime :enableTime - 24 * 60 * 60 * 1000
8. newEnableTime:disableTime + 24 * 60 * 60 * 1000
迴圈遍歷每個結果集中的節點,判斷是否渲染到配載列表中
根據當前節點id判斷是否存在於 stowageList 中,如果存在直接顯示;根據節點id刪除originStowageMapTI集合
更新生失效日期,分別判斷 原始配載中是否存在需要切斷的日期,新新增配載中是否存在需要切斷的日期;然後將當前節點新增到配載列表中
•路由線路配載維護業務核心且頻繁使用功能,為了實現業務述求,將完全沒有關聯的樹形結構和Dom列表結合在一起。採用了多種資料模型+資料結構的組合形式,構造兩者之間的關係,結合遍歷、深度優先搜尋、字串查詢等演演算法進行實現,在春節串點優化專項上線後取得了預期的收益。