css用Flex布局制作简易柱状图的实现
建站知识 2021-07-03 07:55www.168986.cn长沙网站建设
以下是一个用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; margin-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%时的块宽度/ line-height: 30px; font-size: 14px; text-align: right; margin-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!
长沙网站设计
- 如何自己建一个网站 自己想建个网站,怎么建
- 如何制作网站免费建站 创建网站免费注册
- html简单网页代码 html简单网页代码超链接
- dreamweaver网页制作 dreamweaver网页制作模板
- 上海网站建设 上海网站建设制作微信
- 如何制作网站和网页 如何制作一个网页
- html网页制作代码大全 端午节html网页制作代码大
- app开发公司 app开发公司前十名
- html网页制作 html网页制作文字居中
- app制作一个需要多少钱 请人制作一个app多少钱
- 成都网站制作 成都网站制作维护
- 百度建一个网站多少钱 百度做个公司网站要多少
- html+css网页制作成品 web网页制作成品css+javascrip
- html网页制作案例 html网页设计案例
- html+css网页制作成品 web网页制作成品css+javascrip
- 个人网站模板 个人网站模板HTML