当前位置: 首页 > news >正文

带 CSS 样式模式的甘特图开发代码|Highcharts Gantt高级开发示列

带 CSS 样式模式的甘特图完整代码,这是 Highcharts 非常专业的 ** 纯 CSS 控制样式(styledMode)** 用法,完全分离结构与样式,适合企业级、可换肤场景。

完整可运行代码(Styled Mode 纯 CSS 甘特图)

const today = new Date(), day = 1000 * 60 * 60 * 24; // Set to 00:00:00:000 today today.setUTCHours(0); today.setUTCMinutes(0); today.setUTCSeconds(0); today.setUTCMilliseconds(0); // THE CHART Highcharts.ganttChart('container', { chart: { styledMode: true }, title: { text: 'Highcharts Gantt in Styled Mode' }, subtitle: { text: 'Purely CSS-driven design' }, xAxis: { min: today.getTime() - (2 * day), max: today.getTime() + (32 * day) }, accessibility: { keyboardNavigation: { seriesNavigation: { mode: 'serialize' } }, point: { descriptionFormat: '{yCategory}. Start {x:%Y-%m-%d}, end ' + '{x2:%Y-%m-%d}.' } }, lang: { accessibility: { axis: { xAxisDescriptionPlural: 'The chart has a two-part X axis ' + 'showing time in both week numbers and days.' } } }, series: [{ name: 'Project 1', data: [{ name: 'Planning', id: 'planning', start: today.getTime(), end: today.getTime() + (20 * day) }, { name: 'Requirements', id: 'requirements', parent: 'planning', start: today.getTime(), end: today.getTime() + (5 * day) }, { name: 'Design', id: 'design', dependency: 'requirements', parent: 'planning', start: today.getTime() + (3 * day), end: today.getTime() + (20 * day) }, { name: 'Layout', id: 'layout', parent: 'design', start: today.getTime() + (3 * day), end: today.getTime() + (10 * day) }, { name: 'Graphics', parent: 'design', dependency: 'layout', start: today.getTime() + (10 * day), end: today.getTime() + (20 * day) }, { name: 'Develop', id: 'develop', start: today.getTime() + (5 * day), end: today.getTime() + (30 * day) }, { name: 'Create unit tests', id: 'unit_tests', dependency: 'requirements', parent: 'develop', start: today.getTime() + (5 * day), end: today.getTime() + (8 * day) }, { name: 'Implement', id: 'implement', dependency: 'unit_tests', parent: 'develop', start: today.getTime() + (8 * day), end: today.getTime() + (30 * day) }] }] });

这个图表的核心特点(Styled Mode)

styledMode: true—— 开启纯 CSS 样式控制,JS 不写颜色✅任务父子层级(Planning → Design → Develop)✅任务依赖连线(自动箭头)✅时间轴自动以今天为起点官方 CSS 主题highcharts.css完全自定义样式(颜色、边框、连线、悬浮效果)✅无障碍支持 + 键盘导航

必须注意的关键依赖

  1. 必须加载highcharts.cssStyled Mode 必须引入官方 CSS,否则图表无样式。
  2. JS 中不再写color/fill所有颜色、边框、大小全部写在 CSS 里,实现结构样式分离。
  3. 依赖、父子关系自动渲染parent/dependency建立关系,连线自动生成。

你可以直接修改的 CSS 样式示例

/* 任务条颜色 */ .highcharts-point { fill: #b3e5fc; stroke: #0277bd; } /* 依赖连线颜色 */ .highcharts-connector { stroke: #ff6f00; } /* 文字颜色 */ .highcharts-data-label text { fill: #222; }
http://www.cnnetsun.cn/news/2175224.html

相关文章:

  • 国家中小学智慧教育平台电子课本解析工具:一站式PDF下载终极解决方案
  • 2025届学术党必备的十大降AI率工具实际效果
  • 别只调P和I!深入拆解追球小车的双PID控制逻辑:距离保持与角度对准
  • 利用Taotoken访问控制功能,安全管理团队内部AI资源使用
  • R语言做LLM偏见检测,你还在用`prop.test()`?——2024最新面试真题:多组敏感属性嵌套Logistic回归+多重比较校正(Bonferroni vs. BH)实战对比
  • 告别破解!MZ-Tools 8.0.1 官方正版安装与配置全攻略(支持VS2022)
  • 蚂蚁TimeMixer实战:用这个ICLR 2024新模型搞定你的时序预测任务(附PyTorch代码)
  • 告别云端API:手把手教你用Ollama在Mac/Win/Linux本地跑Llama 3和Phi-3(附Docker部署)
  • Pearcleaner架构解析:macOS应用残留文件的系统性清理方案
  • Illustrator脚本架构解析:从自动化工具到设计工作流引擎的技术演进
  • RT-Thread FinSH控制台保姆级使用指南:从串口连接到自定义命令实战
  • Claude 写的代码,到底算谁的?
  • 用Vivado FIFO IP核搞定跨时钟域通信:一个异步FIFO的完整设计实例(附仿真代码)
  • 3分钟快速上手:用easy-topo轻松绘制专业网络拓扑图
  • 2026年潮安高端定制生产厂家如何选材与设计?
  • 别再为传参发愁了!SAP ABAP中CL_HTTP_CLIENT发送POST请求的三种数据格式详解(JSON/Form-data/x-www-form-urlencoded)
  • 金融虚假信息检测中LLM行为偏差与MFMD-Scen基准研究
  • 为什么选择ComfyUI Photoshop插件:5个实战技巧提升AI创作效率300%
  • 原来微信误删记录能免费恢复,可惜很多人不知道
  • 基于Node.js与gRPC的实时文本转语音驱动数字人面部动画实践
  • 一个开发者的AI工具链优化实录:从三个会员到一站搞定
  • 指尖的算法:用PianoPlayer重塑钢琴演奏的智能旅程
  • 告别内存焦虑:用STM32F4的FSMC外扩PSRAM,让你的项目缓存飞起来
  • PvZ Toolkit终极指南:3步解锁植物大战僵尸无限可能
  • 对比直接使用原厂 API 体验 Taotoken 在接入便捷性上的优势
  • 企业内部分享如何通过Taotoken建立统一的AI能力调用与审计规范
  • 基于MCP协议构建AI领域知识库:以神学法典服务器为例
  • 哔咔漫画下载器完整指南:如何3倍速打造个人离线漫画库
  • 告别DLL缺失困扰!VisualCppRedist AIO:Windows运行库终极解决方案
  • 企业级开源资产管理软件:如何用Snipe-IT降低30%IT运维成本