jquery Gantt甘特图简单应用
程序员文章站
2022-05-22 12:37:09
...
最近公司排产需要做个甘特图,做了一个智能排产;
js和css的引用
<link rel="stylesheet" href="css/bootstrap.min.css" />
<script src="js/jquery-2.1.4.min.js"></script>
<script src="js/bootstrap.min.js"></script>
<script src="js/jquery.fn.gantt.js"></script>
jquery.fn.gantt.js是甘特图重要的js文件,网上可以找得到,引用时记得要先引用jq文件否则报错
html:
<div class="gantt"></div>
引用甘特图然后js初始化如下
$(".gantt").gantt({
source: [
{
name: "序号一",
desc: "这是描述1",
values: [{
from: "/Date(1320192000000)/",
to: "/Date(1320592000000)/",
label: "这是描述1",
customClass: "ganttRed",
dataObj: "data1",
desc: '<b>Task #</b>3<br><b>Data</b>: [2018-06-06 15:30:00 - 2018-06-28 16:00:00]',
}]
},{
name: "序号一",
desc: "这是描述1",
values: [{
from: "/Date(1322611200000)/",
to: "/Date(1323302400000)/",
label: "这是描述2",
customClass: "ganttBlue",
dataObj: "data1",
desc: '<b>Task #</b>3<br><b>Data</b>: [2018-06-06 15:30:00 - 2018-06-28 16:00:00]',
},
{from: "/Date(1323802400000)/",
to: "/Date(1325685200000)/",
label: "",
customClass: "ganttOrange"
},
]
}
],
navigate: 'scroll', //buttons scroll
scale: "days", // months weeks days hours
months: ["一月", "二月", "三月", "四月", "五月", "六月", "七月", "八月", "九月", "十月", "十一月", "十二月"],
dow: ["S", "M", "T", "W", "T", "F", "S"],
maxScale: "months",
minScale: "days",
itemsPerPage: 10,
onItemClick: function(data) {
alert("这里是数据区域点击")
},
onAddClick:function() {
alert("这里是无数据区域点击")
},
onRender: function() {
}
});
重点数据结构介绍
source:是获取的后台数据结构如上,name是左边的***也可以是其他,desc是名称等等效果如下
values: [{
from: "/Date(1320192000000)/",
to: "/Date(1320592000000)/",
label: "这是描述1",
customClass: "ganttRed",
dataObj: "data1",
desc: '<b>Task #</b>3<br><b>Data</b>: [2018-06-06 15:30:00 - 2018-06-28 16:00:00]',
}]
valuse是右边的数据条
form是开始时间,to是结束时间,form和to里面Date传入的值是时间戳,
label是数据条上显示的文本,
customClass是颜色,
desc:这里的desc是鼠标移入是显示的模块数据可以是html代码块,
dataObj:是点击数据时点击事件获取的数据;
navigate:是否横向滚动条 可选buttons 或scroll;
scale:可选months weeks days hours,年月日时显示数据;
months:里面传入12月可以是英文*定义;
dow:里面传入星期可以是英文*定义;
itemsPerPage:是显示数据的行数多余的会自动分页;
onItemClick:这里是数据区域点击事件,data拿到的是dataObj;
onAddClick:这里是无数据区域点击事件;
onRender:加载时执行的事件;
另外如果一行有两条数据的话数据结构如下
values: [{
from: "/Date(1322611200000)/",
to: "/Date(1323302400000)/",
label: "这是描述2",
customClass: "ganttBlue",
dataObj: "data1",
desc: '<b>Task #</b>3<br><b>Data</b>: [2018-06-06 15:30:00 - 2018-06-28 16:00:00]',
},
{from: "/Date(1323802400000)/",
to: "/Date(1325685200000)/",
label: "",
customClass: "ganttOrange"
},
]
style:
.gantt{width:100%;border:1px solid #ddd;position:relative;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.gantt:after{content:".";visibility:hidden;display:block;height:0;clear:both}.fn-gantt{width:100%}.fn-gantt *,.fn-gantt *:after,.fn-gantt *:before{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.fn-gantt .fn-content{overflow:hidden;position:relative;width:100%}.fn-gantt .row{float:left;height:24px;line-height:24px;margin:0}.fn-gantt .leftPanel{float:left;width:280px;overflow:hidden;border-right:1px solid #DDD;position:relative;z-index:20;height:655px}.fn-gantt .leftPanel .fn-label{display:inline-block;margin:0 0 0 5px;color:#484a4d;width:110px;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.fn-gantt .leftPanel .row{border-bottom:1px solid #DDD}.fn-gantt .leftPanel .name,.fn-gantt .leftPanel .desc{float:left;height:24px;width:50%;background-color:#f6f6f6}.fn-gantt .leftPanel .name{font-weight:bold}.fn-gantt .leftPanel .fn-wide,.fn-gantt .leftPanel .fn-wide .fn-label{width:100%}.fn-gantt .leftPanel .spacer{background-color:#f6f6f6;width:100%}.fn-gantt .rightPanel{overflow:hidden}.fn-gantt .dataPanel{margin-left:0;outline:1px solid #DDD;background-image:url(img/grid.png);background-repeat:repeat;position:relative}.fn-gantt .row.header{margin-right:-1px;width:100%}.fn-gantt .day,.fn-gantt .date{overflow:visible;width:24px;line-height:24px;text-align:center;border-right:1px solid #DDD;border-bottom:1px solid #DDD;font-size:11px;color:#484a4d;text-shadow:0 1px 0 rgba(255,255,255,0.75);text-align:center}.fn-gantt .sa,.fn-gantt .sn,.fn-gantt .wd{height:24px;text-align:center}.fn-gantt .sa,.fn-gantt .sn{color:#939496;background-color:#f5f5f5;text-align:center}.fn-gantt .wd{background-color:#f6f6f6;text-align:center}.fn-gantt .holiday{background-color:#ffd263;height:24px}.fn-gantt .today{background-color:#fff8da;height:24px;font-weight:bold;text-align:center}.fn-gantt .rightPanel .month,.fn-gantt .rightPanel .year{float:left;overflow:hidden;border-right:1px solid #DDD;border-bottom:1px solid #DDD;height:24px;background-color:#f6f6f6;font-weight:bold;font-size:11px;color:#484a4d;text-shadow:0 1px 0 rgba(255,255,255,0.75);text-align:center}.fn-gantt-hint{border:5px solid #edc332;background-color:#fff5d4;padding:10px;position:absolute;display:none;z-index:11;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.fn-gantt .bar{background-color:#d0e4fd;height:18px;margin:0 3px 3px 0;position:absolute;z-index:10;text-align:center;-webkit-box-shadow:0 0 1px rgba(0,0,0,0.25) inset;-moz-box-shadow:0 0 1px rgba(0,0,0,0.25) inset;box-shadow:0 0 1px rgba(0,0,0,0.25) inset;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.fn-gantt .bar .fn-label{line-height:18px;font-weight:bold;white-space:nowrap;width:100%;text-overflow:ellipsis;overflow:hidden;text-shadow:0 1px 0 rgba(255,255,255,0.4);color:#414b57!important;text-align:center;font-size:11px}.fn-gantt .ganttRed{background-color:#f9c4e1}.fn-gantt .ganttRed .fn-label{color:#78436d!important}.fn-gantt .ganttGreen{background-color:#d8eda3}.fn-gantt .ganttGreen .fn-label{color:#778461!important}.fn-gantt .ganttOrange{background-color:#fcd29a}.fn-gantt .ganttOrange .fn-label{color:#714715!important}.fn-gantt .bottom{clear:both;background-color:#f6f6f6;width:100%}.fn-gantt .navigate{border-top:1px solid #DDD;padding:10px 0 10px 225px}.fn-gantt .navigate .nav-slider{height:20px;display:inline-block}.fn-gantt .navigate .nav-slider-left,.fn-gantt .navigate .nav-slider-right{text-align:center;height:20px;display:inline-block}.fn-gantt .navigate .nav-slider-left{float:left}.fn-gantt .navigate .nav-slider-right{float:right}.fn-gantt .navigate .nav-slider-content{text-align:left;width:160px;height:20px;display:inline-block;margin:0 10px}.fn-gantt .navigate .nav-slider-bar,.fn-gantt .navigate .nav-slider-button{position:absolute;display:block}.fn-gantt .navigate .nav-slider-bar{width:155px;height:6px;background-color:#838688;margin:8px 0 0 0;-webkit-box-shadow:0 1px 3px rgba(0,0,0,0.6) inset;-moz-box-shadow:0 1px 3px rgba(0,0,0,0.6) inset;box-shadow:0 1px 3px rgba(0,0,0,0.6) inset;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.fn-gantt .navigate .nav-slider-button{width:17px;height:60px;background:url(img/slider_handle.png) center center no-repeat;left:0;top:0;margin:-26px 0 0 0;cursor:pointer}.fn-gantt .navigate .page-number{display:inline-block;font-size:10px;height:20px}.fn-gantt .navigate .page-number span{color:#666;margin:0 6px;height:20px;line-height:20px;display:inline-block}.fn-gantt .navigate a:link,.fn-gantt .navigate a:visited,.fn-gantt .navigate a:active{text-decoration:none}.fn-gantt .nav-link{margin:0 3px 0 0;display:inline-block;width:20px;height:20px;font-size:0;background:#595959 url(img/icon_sprite.png)!important;border:1px solid #454546;cursor:pointer;vertical-align:top;-webkit-border-radius:2px;-moz-border-radius:2px;border-radius:2px;-webkit-box-shadow:0 1px 0 rgba(255,255,255,0.1) inset,0 1px 1px rgba(0,0,0,0.2);-moz-box-shadow:0 1px 0 rgba(255,255,255,0.1) inset,0 1px 1px rgba(0,0,0,0.2);box-shadow:0 1px 0 rgba(255,255,255,0.1) inset,0 1px 1px rgba(0,0,0,0.2);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.fn-gantt .nav-link:active{-webkit-box-shadow:0 1px 1px rgba(0,0,0,0.25) inset,0 1px 0 #FFF;-moz-box-shadow:0 1px 1px rgba(0,0,0,0.25) inset,0 1px 0 #FFF;box-shadow:0 1px 1px rgba(0,0,0,0.25) inset,0 1px 0 #FFF}.fn-gantt .navigate .nav-page-back{background-position:1px 0!important;margin:0}.fn-gantt .navigate .nav-page-next{background-position:1px -16px!important;margin-right:15px}.fn-gantt .navigate .nav-slider .nav-page-next{margin-right:5px}.fn-gantt .navigate .nav-begin{background-position:1px -112px!important}.fn-gantt .navigate .nav-prev-week{background-position:1px -128px!important}.fn-gantt .navigate .nav-prev-day{background-position:1px -48px!important}.fn-gantt .navigate .nav-next-day{background-position:1px -64px!important}.fn-gantt .navigate .nav-next-week{background-position:1px -160px!important}.fn-gantt .navigate .nav-end{background-position:1px -144px!important}.fn-gantt .navigate .nav-zoomOut{background-position:1px -96px!important}.fn-gantt .navigate .nav-zoomIn{background-position:1px -80px!important;margin-left:15px}.fn-gantt .navigate .nav-now{background-position:1px -32px!important}.fn-gantt .navigate .nav-slider .nav-now{margin-right:5px}.fn-gantt-loader{position:absolute;width:100%;height:100%;left:0;top:0;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#bf000000',endColorstr='#bf000000',GradientType=0);background:rgba(0,0,0,0.75);cursor:wait;z-index:30}.fn-gantt-loader-spinner span{position:absolute;margin:auto;top:0;right:0;bottom:0;left:0;width:100%;text-align:center;height:1em;line-height:1em;color:#fff;font-size:1em;font-weight:bold}.row:after{clear:both}
上一篇: jquery甘特图插件
下一篇: Java 线程安全相关