css用Flex布局制作简易柱状图的实现
网站建设 2023-01-28 21:39www.1681989.com免费网站
以下是一个用Flex布局的柱状图
HTML
<div class="his_box"> <div>成绩分布直方图</div> <div class="histogram"> <div><div>10</div></div> <div><div>8</div></div> <div><div>15</div></div> <div><div>12</div></div> <div><div>5</div></div> </div> </div>
CSS
.his_box{ /盒子/ width: 400px; height: 220px; border: solid 1px #1E90FF; display: flex; flex-direction: column; align-items: center; } .histogram{ /直方图/ display: flex; } .histogram>div{ /一条图块/ width: 30px; height: 200px; /100%时的块高度/ font-size: 14px; text-align: center; marg-right: 5px; display: flex; flex-direction: column-reverse; } .histogram>div:nth-child(3n) div{ /图块颜色/ background-color: #ff404b; } .histogram>div:nth-child(3n+1) div{ background-color: #99CCFF; } .histogram>div:nth-child(3n+2) div{ background-color: #F0AD4E; } .histogram>div:nth-child(1) div{ flex: 0 0 50%; /20为100%,50%就是10/ } .histogram>div:nth-child(2) div{ flex: 0 0 40%; /8/20/ } .histogram>div:nth-child(3) div{ flex: 0 0 75%; /15/20/ } .histogram>div:nth-child(4) div{ flex: 0 0 60%; /12/20/ } .histogram>div:nth-child(5) div{ flex: 0 0 25%; /5/20/ }
本例中,图块的最高点为20,每条柱子的高度按比例定义第1条数据为10,高度是50%;第2条数据为8,高度为40%,以此类推。
图块颜色采用3色循环使用。
布局时,最外层容器使用了align-items: center;使容器内元素整体居中。
直方图模块使用了display: flex;让模块中的柱子横向排列。
每条柱子也是flex模块,但它的布局方向是纵向的,且方向是从下到上的 flex-direction: column-reverse;
如果想做成纵向排列的直方图
CSS
.his_box{ /盒子/ width: 400px; height: 220px; border: solid 1px #1E90FF; display: flex; flex-direction: column; justify-content: space-between; } .his_box>div{ text-align: center; } .histogram{ /直方图/ display: flex; flex-direction: column; } .histogram>div{ /一条图块/ height: 30px; width: 200px; /100%时的块宽度/ le-height: 30px; font-size: 14px; text-align: right; marg-bottom: 5px; display: flex; } .histogram>div:nth-child(3n) div{ /图块颜色/ background-color: #ff404b; } .histogram>div:nth-child(3n+1) div{ background-color: #99CCFF; } .histogram>div:nth-child(3n+2) div{ background-color: #F0AD4E; } .histogram>div:nth-child(1) div{ flex: 0 0 50%; /20为100%,50%就是10/ } .histogram>div:nth-child(2) div{ flex: 0 0 40%; /8/20/ } .histogram>div:nth-child(3) div{ flex: 0 0 75%; /15/20/ } .histogram>div:nth-child(4) div{ flex: 0 0 60%; /12/20/ } .histogram>div:nth-child(5) div{ flex: 0 0 25%; /5/20/ }
到此这篇关于css用Flex布局制作简易柱状图的实现的文章就介绍到这了,更多相关css柱状图内容请搜索狼蚁SEO以前的文章或继续浏览狼蚁网站SEO优化的相关文章,希望大家以后多多支持狼蚁SEO!
网站设计
- 静宁会SEO的网站建设公司:全面提升您的网络影
- 提升在线业务的关键:选择最佳的丽水网站建设
- 浙江网站优化发展潜力如何
- 井研专业的网站建设公司:打造您的在线品牌
- 灵山SEO网站建设公司:提升您的在线业务表现
- 蒙城网站建设优化公司:提升您网站表现的理想
- 阳谷企业网站优化:提升线上业务力的关键
- 樟树专业的网站建设公司:打造您在线业务的坚
- 通河百度SEO排名的策略与技巧
- 重庆百度快照排名如何进行精准的客户引流
- 重庆百度快照排名
- 常宁便宜的建站公司:助您轻松打造在线业务
- 巫溪百度网站优化:提升网站曝光率与流量的关
- 湖北整站优化怎么做才能放大客户需求
- 闸北网站建设多少钱?全面解析与预算规划
- 辽宁企业网站优化怎么做电话营销