HTML中使用Vue+Dhtmlxgantt制作任务进度图
HTML中使用Vue+Dhtmlxgantt制作任务进度图
Dhtmlxgantt官网: https://dhtmlx.com/docs/products/dhtmlxGantt/
参考文章
甘特图配置大佬翻译的官方文档 ,https://blog.csdn.net/qq_24472595/article/details/81630117;
实现搜索 新增 编辑 删除 设置具体时间格式 突出周末显示https://blog.csdn.net/CX_silent/article/details/83589451
从0开始使用Dhtmlxgantt https://blog.csdn.net/honantic/article/details/51314672 ;
代码部分
HTML部分:
//需要引用dhtmlxgantt.css、dhtmlxgantt.js、locale_cn.js(汉化文件)
<div>
<div id="gantt_here" style='width:100%; height:550px;' ref="gantt"></div>
</div>
js部分:
$(function () {
window.App = new Vue({
el: "#app",
data: function () {
return {
tasks: {
data: []
}
}
};
},
methods: {
QueryClick: function () {
var that = this;
//每次点击查询前清空
that.InitData();
that.Ajax({
url: "/JHProcess/GetProcessContrast",//从后台读取数据
data: {
XXXX//后台查询条件
},
success: function (result) {
var data = result.Data.Data;
var arry = [];
for (var i = 0; i < data.length; i++) {
var current = data[i];
arry.push({
text: current.名称,
start_date: new Date(current.开始时间),
end_date: new Date(current.结束时间),
duration: that.DateDifference(current.开始时间, current.结束时间),
progress: Number((current.计划进度 / current.本年投资计划完成).toFixed(2))
});
}
that.tasks.data = arry;
that.Init(); //加载数据之后初始化
}
});
},
weekScaleTemplate: function (date) {
var dateToStr = gantt.date.date_to_str("%d%M");
var weekNum = gantt.date.date_to_str("(周%W)");
var endDate = gantt.date.add(gantt.date.add(date, 1, "week"), - 1, "day");
return dateToStr(date) + " - " + dateToStr(endDate) + "" + weekNum(date);
},
DateDifference: function (strDateStart, strDateEnd) {
var begintime_ms = Date.parse(new Date(strDateStart.replace(/-/g, "/"))); //begintime 为开始时间
var endtime_ms = Date.parse(new Date(strDateEnd.replace(/-/g, "/"))); // endtime 为结束时间
var date3 = endtime_ms - begintime_ms; //时间差的毫秒数
var days = Math.floor(date3 / (24 * 3600 * 1000));
return days;
},
Init: function () {
var that = this;
gantt.config.scale_unit = "month"; //时间坐标轴单位“minute”, “hour”, “day”, “week”, “quarter”, “month”, “year”
gantt.config.date_scale = "%d,%D";//日期格式 先数字后文字
gantt.config.row_height = 30; //甘特图的行高
gantt.config.scale_height = 20;//甘特图的表头高度
gantt.config.scroll_on_click = false;
gantt.config.min_column_width = 60;
gantt.config.duration_unit = "day";
gantt.config.scale_height = 20 * 3;
//gantt.config.row_height = 28;
gantt.config.drag_resize = false;//两边不可拖动
gantt.config.readonly = true;//只读模式
gantt.config.subscales = [{ //时间坐标为月份的时候 先显示年份再月份
unit: "month",
step: 1,
date: "%Y,%F"
}];
//配置显示列 //name:绑定数据的名称 align:对其方式 label显示在表头的名称
gantt.config.columns = [
{ name: "text", tree: true, width: '*', align: "center", label: "计划名称", resize: true },
{ name: "start_date", align: "center", resize: true },
{ name: "end_date", align: "center", label: "结束时间", resize: true },
{ name: "duration", align: "center" }
];
//显示到进度条上的文本 计划名称和任务进度百分比
gantt.templates.task_text = function (start, end, task) {
return "<b style='text-align:left;'>计划名称:</b> " + task.text +" <span style='text-align:left;'>" +"完成计划:"+ Math.round(task.progress * 100) + "% </span>";
};
gantt.init(that.$refs.gantt); gantt.parse(that.tasks);
},
InitData: function () {
//清空数据
gantt.clearAll();
}
},
mounted() {
var that = this;
that.Ajax = top.Helper.Current.Ajax;
//注入一个用户信息
that.User = top.Helper.Current.User;
console.log(that.$refs.gantt);
that.SizeChange = function () {
var that = this;
var h = $("#app").height();
if (that.WindowSize != h) {
that.WindowSize = (h - 135);
console.log(that.WindowSize);
}
};
gantt.config.min_column_width = 60;
gantt.config.scale_height = 20 * 3;
gantt.config.subscales = [{
unit: "month",
step: 1,
date: "%Y,%F"
}];
//配置显示列 //name:绑定数据的名称 align:对其方式 label显示在表头的名称
gantt.config.columns = [
{ name: "text", tree: true, width: '*', align: "center", label: "计划名称", resize: true },
{ name: "start_date", align: "center", resize: true },
{ name: "end_date", align: "center", label: "结束时间", resize: true },
{ name: "duration", align: "center" }
];
gantt.init(that.$refs.gantt);
}
});
});
HTML中使用Vue+Dhtmlxgantt制作任务进度图的更多相关文章
- 使用Vue.js制作仿Metronic高级表格(一)静态设计
Metronic高级表格是Metonic框架中自行实现的表格,其底层是Datatables.本教程将主要使用Vue实现交互部分,使用Bootstrap做样式库.jQuery做部分用户交互(弹窗). 使 ...
- webstorm中关于vue的一些问题
在进行vue开发中,我使用了webstorm,但是过程坎坷艰辛,遇到了很多问题,我将问题和解决方案贴上,以作参考. 1.vue项目部署在webstorm中,第一个遇到的问题是,webstorm卡住了, ...
- 在pycharm中开发vue
一.在pycharm中开发vue ''' webstorm(vue) pycharm(python) goland(Go语言) idea(java) andrioStuidio(安卓) Php(PHP ...
- vue生命周期图示中英文版Vue实例生命周期钩子
vue生命周期图示中英文版Vue实例生命周期钩子知乎上近日有人发起了一个 “react 是不是比 vue 牛皮,为什么?” 的问题,Vue.js 作者尤雨溪12月4日正面回应了该问题.以下是尤雨溪回复 ...
- 在webpack构建的项目中使用vue
一.复习在普通网页中使用vue1.使用script引入vue2.在index中创建 id为app的容器3.通过new vue得到vm实例二.在webpack中尝试使用vue://注意 : 在webpa ...
- django项目中使用项目环境制作脚本 通过终端命令运行脚本文件
在实际的django项目开发中,有时候需要制作一些脚本文件对项目数据进行处理,然后通过终端命令运行脚本. 完整的实现流程如下: 1.在一个应用目录下(app, 必须是在应用目录下,可以专门创建一个应用 ...
- 在webpack中配置vue.js
在webpack中配置vue.js 这里有两种在webpack中配置vue.js的方法,如下: 1.在main.js中引入vue的包: index.html: <!DOCTYPE html> ...
- IDEA 中使用 Vue 提示 namespace is not bound
今天在 IDEA 中使用 vue.js 时提示我如下错误信息 解决方法: 把这个校验项目去掉就可以了.
- webstorn中的vue文件识别es6代码
webstorn中的vue文件识别es6代码 1.webstorm中es6语法报错,解决方法: 打开 Settings => Languages & Frameworks => J ...
随机推荐
- [转]Win10下安装Linux子系统
工作以来一直DotNet系偏C/S, 接触Web开发的时间也不长, 现在主要偏向Web全栈方向, 一直对Linux系统心生向往, 夜深了娃睡了, 打开老旧的笔记本来折腾一下. 准备工作 控制面板 &g ...
- 添加gitignore文件后使其生效
https://www.cnblogs.com/AliliWl/p/7880243.html 遇到的问题 我们发现在添加.gitignore文件后,当我们想push文件的时候,我们声明的忽略文件还是会 ...
- P1074 彩票摇奖
题目描述 为了丰富人民群众的生活.支持某些社会公益事业,北塔市设置了一项彩票.该彩票的规则是: (1) 每张彩票上印有 7 个各不相同的号码,且这些号码的取指范围为 1~33. (2) 每次在兑奖前都 ...
- 802.1X的体系结构
- linux单 open 设备
提供存取控制的强力方式是只允许一个设备一次被一个进程打开(单次打开). 这个技术最 好是避免因为它限制了用户的灵活性. 一个用户可能想运行不同的进程在一个设备上, 一 个读状态信息而另一个写数据. 在 ...
- ASP.NET MVC4.0+EF+LINQ+bui+bootstrap+网站+角色权限管理系统(开篇)
系统预览: 源码下载:http://www.yealuo.com/Home/Detail?KeyValue=2f926407-f80b-4bff-a729-949a53efed7b 创建项目,新手按步 ...
- 牛客小白月赛15A 斑羚飞渡
链接:https://ac.nowcoder.com/acm/contest/917/A 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K,其他语言262144K 64b ...
- Luogu P4173 残缺的字符串-FFT在字符串匹配中的应用
P4173 残缺的字符串 FFT在字符串匹配中的应用. 能解决大概这种问题: 给定长度为\(m\)的A串,长度为\(n\)的B串.问A串在B串中的匹配数 我们设一个函数(下标从\(0\)开始) \(C ...
- Java中大量if...else语句的消除替代方案
在我们平时的开发过程中,经常可能会出现大量If else的场景,代码显的很臃肿,非常不优雅.那我们又没有办法处理呢? 针对大量的if嵌套让代码的复杂性增高而且难以维护.本文将介绍多种解决方案. 案例 ...
- Struts2 注释类型
Struts 2 应用程序可以使用Java5注释作为替代XML和Java属性配置.这里是清单的不同的类别有关的最重要的注解: 命名空间注释(动作注释): @ Namespace注释允许在Action类 ...