翻譯|使用教程|編輯:秦林|2022-10-24 14:02:31.003|閱讀 585 次
概述:本文給大家帶來dhtmlxGantt如何自定義縮放時間尺度。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關鏈接:
這篇文章給大家帶來dhtmlxGantt如何自定義縮放時間尺度。
dhtmlxGantt提供了一個內置模塊,用于方便地管理時間尺度縮放。如果您想自定義默認縮放行為,有一個靈活的 API 允許您實現動態更改時間刻度設置的能力。
嵌入式縮放模塊在gantt.ext.zoom擴展中聲明。要啟用該模塊,您需要調用gantt.ext.zoom.init(zoomConfig)并傳遞一個帶有配置設置的zoomConfig對象,其中包含一組縮放級別。例如:
var zoomConfig = { levels: [ { name:"day", scale_height: 27, min_column_width:80, scales:[ {unit: "day", step: 1, format: "%d %M"} ] }, { name:"week", scale_height: 50, min_column_width:50, scales:[ {unit: "week", step: 1, format: function (date) { var dateToStr = gantt.date.date_to_str("%d %M"); var endDate = gantt.date.add(date, 6, "day"); var weekNum = gantt.date.date_to_str("%W")(date); return "#" + weekNum + ", " + dateToStr(date) + " - " + dateToStr(endDate); }}, {unit: "day", step: 1, format: "%j %D"} ] }, { name:"month", scale_height: 50, min_column_width:120, scales:[ {unit: "month", format: "%F, %Y"}, {unit: "week", format: "Week #%W"} ] }, { name:"quarter", height: 50, min_column_width:90, scales:[ {unit: "month", step: 1, format: "%M"}, { unit: "quarter", step: 1, format: function (date) { var dateToStr = gantt.date.date_to_str("%M"); var endDate = gantt.date.add(gantt.date.add(date, 3, "month"), -1, "day"); return dateToStr(date) + " - " + dateToStr(endDate); } } ]}, { name:"year", scale_height: 50, min_column_width: 30, scales:[ {unit: "year", step: 1, format: "%Y"} ]} ] }; gantt.ext.zoom.init(zoomConfig);
如果您不想使用縮放模塊并且更喜歡手動控制縮放設置,您可以通過相應的配置選項來實現。
事實上,實現縮放功能意味著定義時間尺度配置(縮放級別)的多個預設,并為用戶提供在它們之間切換的能力。
您需要以下設置來配置時間刻度:
讓我們考慮以下預設:
/* global gantt */ function setScaleConfig(level) { switch (level) { case "day": gantt.config.scales = [ {unit: "day", step: 1, format: "%d %M"} ]; gantt.config.scale_height = 27; break; case "week": var weekScaleTemplate = function (date) { var dateToStr = gantt.date.date_to_str("%d %M"); var endDate = gantt.date.add(gantt.date.add(date, 1, "week"), -1, "day"); return dateToStr(date) + " - " + dateToStr(endDate); }; gantt.config.scales = [ {unit: "week", step: 1, format: weekScaleTemplate}, {unit: "day", step: 1, format: "%D"} ]; gantt.config.scale_height = 50; break; case "month": gantt.config.scales = [ {unit: "month", step: 1, format: "%F, %Y"}, {unit: "day", step: 1, format: "%j, %D"} ]; gantt.config.scale_height = 50; break; case "year": gantt.config.scales = [ {unit: "year", step: 1, format: "%Y"}, {unit: "month", step: 1, format: "%M"} ]; gantt.config.scale_height = 90; break; } }
所描述的功能可以通過從“日”到“年”時間尺度的四個預定義配置之一來配置甘特圖對象。甘特圖將需要完全重繪以顯示配置更改:
setScaleConfig("year"); gantt.init("gantt_here");
然后你可以為用戶實現一個 UI 來切換縮放級別:
<label><input type="radio" name="scale" value="day" checked/>Day scale</label> <label><input type="radio" name="scale" value="week"/>Week scale</label> <label><input type="radio" name="scale" value="month"/>Month scale</label> <label><input type="radio" name="scale" value="year"/>Year scale</label> var els = document.querySelectorAll("input[name='scale']"); for (var i = 0; i < els.length; i++) { els[i].onclick = function(e){ var el = e.target; var value = el.value; setScaleConfig(value); gantt.render(); }; }
dhtmlxGantt享有超十年聲譽,支持跨瀏覽器和跨平臺,性價比高,可滿足項目管理控件應用的所有需求,是最完善的甘特圖圖表庫。了解更多內容,歡迎在線咨詢或者私信我獲取正版試用版及報價。
甘特圖控件交流群:764148812 歡迎進群交流討論
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn