您现在的位置是:网站首页> 编程资料编程资料
CSS 实现蜂巢/六边形图集的示例代码css3实现六边形边框的实例代码css画正六边形的两种方法css实现六边形图片的示例代码CSS实现图片背景填充的六边形的示例代码CSS3绘制六边形的简单实现纯css绘制蜂巢六边形效果纯css实现的六边形(蜂窝)导航效果(支持hover/兼容浏览器)
2021-09-03
1310人已围观
简介 这篇文章主要介绍了CSS 实现蜂巢/六边形图集的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
不知道为什么,UI 很喜欢设计蜂巢效果(摊手)
一、实现六边形
首先用传统的方式来分析一下六边形

可以拆分成三个矩形,每个矩形 旋转正负 60° 得到其它两个矩形
由此可以设计出基本的 HTML 结构

矩形的宽高先随便设置,后面组件化的时候再计算其关系,通过 props 设置
然后设置 CSS 样式
.w-comb { background-color: #e4e4e4; display: inline-block; position: relative; } .w-comb-sub1, .w-comb-sub2 { background-color: #e4e4e4; position: absolute; width: inherit; height: inherit; } .w-comb-sub1 { transform: rotate(-60deg); } .w-comb-sub2 { transform: rotate(60deg); }一个六边形就完成了

不过这只是传统的方式,如果不考虑兼容性问题 ,可以直接使用 clip-path 画一个六边形
.w-comb { clip-path: polygon( 0 25%, 50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75% ); }非常简单粗暴!不需要子节点不需要旋转,只要一行代码,六边形带回家!
二、设置尺寸
实际的应用场景通常都是一堆六边形拼在一起,所以需要将单个六边形处理为组件
首先的问题就是,如何设置六边形的尺寸,这需要用一下初中学到的数学知识

经过计算,当矩形的长为 x 的时候,宽(边长 a )为

对角线 b 为

然后就能规定六边形的尺寸
如果是 三个矩形旋转而成的 传统方案:
// 传统方案 const RADICAL_3 = 1.7320508; const Comb = (props) => { const { className } = props; const width = props.size || 80; const height = Math.ceil(width / RADICAL_3); return ( ) }如果是直接 使用 clip-path 绘制 的六边形:
// clip-path const RADICAL_3 = 1.7320508; const Comb = (props) => { const { className } = props; const width = props.size || 80; const height = 2 * Math.ceil(width / RADICAL_3); return ( ) }三、排列蜂巢
定义一个 spacing 字段,用来设置 margin-right,然后排列出一排六边形


再生成第二排的时候,需要调整一下 top 和 left
left 为矩形长 ( x ) 的一半(这是基础偏移量,实际需要的距离在这个数字上增加)
而 top 则为六边形边长 ( a ) 的一半的一半(基础偏移量)
后面每一行的 top 都会增加,而 left 仅在偶数行生效

四、添加内容
在传统方案中,是以横向的矩形为基础,所以六边形的内容可以直接写在矩形里


到此这篇关于CSS 实现蜂巢/六边形图集的示例代码的文章就介绍到这了,更多相关CSS六边形图集内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
相关内容
- js判断并告知支持css属性(值)的 情况分析CSS 有序或者无序列表的前面的标记 list-style-type 属性的实现css浮动 float属性详解css选择器四大类:基本、组合、属性、伪类详解CSS3新增的背景属性
- CSS实现QQ浏览器功能CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- css实现两列固定与一列自适应的几种方法利用纯css实现table固定列与表头中间横向滚动的思路和实例CSS固定宽度的三列布局运用实例解析横向两列布局(左列固定,右列自适应)的4种CSS实现方式CSS三列布局两端固定宽度中间自适应css 固定表头 拖动滚动条时对应表头所对应的列 ie6测试通过CSS教程:三列固定网页布局实例
- css sticky footer经典布局的实现CSS Sticky Footer 几种实现方式CSS Sticky Footer实现代码CSS实现Sticky Footer的示例代码详解CSS经典布局之Sticky footer布局详解Sticky Footer 绝对底部的两种套路
- 解决CSS浏览器兼容性问题的4种方案对常见的css属性进行浏览器兼容性总结(推荐)CSS浏览器兼容性常见问题总结大全(推荐)详解CSS3浏览器兼容浅谈各种浏览器下的CSS Hack兼容性写法CSS3中的Opacity多浏览器透明度兼容性问题CSS浏览器兼容性Hack大全2013年五大主流浏览器 HTML5 与 CSS3 兼容性大比拼CSS对浏览器的兼容性性处理(IE7,6与Fireofx)常见浏览器兼容性问题与解决方案css篇CSS实现兼容性的渐变背景(gradient)效果兼容众多浏览器
- css样式层叠规则详解css3+svg实现创意图片层叠音乐播放样式代码CSS中层叠上下文的具体使用css 层叠与z-index的示例代码CSS 中重要的层叠概念详解详解CSS中的特指度和层叠问题
- CSS3实现文字浮雕效果,镂刻效果,火焰文字CSS3 实现的火焰动画通过CSS的滤镜实现火焰效果的示例如何通过 CSS 写出火焰效果
- 解决移动端1px边框问题的几种方法(5种)详解移动端Html5页面中1px边框的几种解决方法reset.css引入以及1px边框问题的解决方法解决移动端1px边框最好的方法(推荐)
- CSS3实现水平居中、垂直居中、水平垂直居中的实例代码使用CSS实现盒子水平垂直居中的方法(8种)CSS 水平居中并限定最大的宽度实现CSS实现子元素div水平垂直居中的示例CSS中的translate(-50%,-50%)实现水平垂直居中效果css3 flex实现div内容水平垂直居中的几种方法CSS3 不定高宽垂直水平居中的几种方式手把手教你CSS水平、垂直居中的10种方式(小结)web前端之css水平居中代码解析
- 快速解决css使用@keyframes加载图片首次循环时出现白色间隙问题(闪屏)详解CSS 去掉inline-block元素间隙的几种方法 CSS图片下面有间隙的6种解决方案css几种解决inline-block间隙的方案(整理)css解决display:inline-block;产生的缝隙(间隙)的方法详解CSS清除图片下几像素空白间隙的方法
