试坑不完美的 clip-path (我说的 CSS 的那个)
需求跟我说,咱们要创新,想做一个蜂巢状的列表,年少无知的我竟然一口答应了,全然因为刚接触了 clip-path;
But,然而,不幸的是,这只是坎坷路途的开始....
clip-path 的教程很多了,在此就不赘述了,
比 clip: rect() 这个弃子不知道高级了多少倍,苦等多年用 CSS 玩 SVG 的感觉已经有了一丢丢(虽然还有很多没有)
两个参数,一个盒子范围(可选)和 一个剪切形状
/* 圆形 */
clip-path: padding-box circle(50px at 0 100px); /* padding-box 盒模式下剪切成中心在 0 100px,半径 50px 的圆 */ /* 多边形 */
clip-path: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%); /* 正六边形 */ /* 椭圆 */
clip-path: ellipse(65px 30px at 125px 40px); /* 方形 */
clip-path: inset(10px, 0, 10rem, 1em); /* 当时老诧异了,为什么 clip:rect() 不是这样算边界的 */ /* 圆角 */
clip-path: inset(10% 10% 10% 10% round 20%, 20%);
但兼容性就很尴尬了呀,基本只有 -webkit- 能玩了,
还好公司是做移动端的,测试大部分手机还没发现问题,但老版安卓和各大 app 里面的浏览器怎么样就很难说了...
虽然神奇的是点击范围也成了剪切后的范围,但依旧有些需求没法达成。(border-radius 可以用 polygon 搞)
比如 border, box-shadow 的效果不是想象中那样呀,子级或内部文本范围并非剪切范围 等
但需求还是要完成呀,真是需求和程序的千年虐恋...
后来又试了些办法...比如 SVG 的 <clipPath> 和 <mask>,border 等,都不能满足需求。
比如,点击范围,背景图不统一,没法加边框和阴影之类的。
现在使用的是三个 DIV 的旋转来构成,看一下这冗长的代码:
.comb {
position: relative;
}
.comb:before {
content: "";
padding-top: 86.602%;
display: block;
margin: 0 -14.433%;
}
.comb-shape {
position: absolute;
top: 0%;
bottom: 0%;
left: 25%;
right: 25%;
z-index: 1;
opacity: 0.9;
background-size: 0 0;
}
.comb-shape:hover {
opacity: 1;
}
.horn1, .center, .horn2 {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
display: block;
background-image: inherit;
overflow: hidden;
}
.center {
background-repeat: no-repeat;
background-position: center;
background-size: auto 120%;
}
.horn1, .horn2 {
background-size: 0 0;
}
.horn1 {
transform: rotate(60deg);
}
.horn2 {
transform: rotate(-60deg);
}
.horn1:before, .horn2:before {
content: "";
position: absolute;
top: 0;
bottom: 0;
left: -50%;
right: -50%;
background-image: inherit;
background-repeat: no-repeat;
background-position: center;
background-size: auto 120%;
}
.horn1:before {
transform: rotate(-60deg);
}
.horn2:before {
transform: rotate(60deg);
}
.border .center,
.border .horn1,
.border .horn2 {
border-top: 2px solid #000;
border-bottom: 2px solid #000;
}
<div class="comb">
<div class="comb-shape" style="background-image: url(img/lake2.png);">
<a class="horn1" href="#"></a>
<a class="horn2" href="#"></a>
<a class="center" href="#"></a>
</div>
</div>
没办法了,先这样吧,现实都不美好,我对新世界充满了期待...
试坑不完美的 clip-path (我说的 CSS 的那个)的更多相关文章
- CLIP PATH (MASK) GENERATOR是一款在线制作生成clip-path路径的工具,可以直接生成SVG代码以及配合Mask制作蒙板。
CLIP PATH (MASK) GENERATOR是一款在线制作生成clip-path路径的工具,可以直接生成SVG代码以及配合Mask制作蒙板. CLIP PATH (MASK) GENERATO ...
- rabbitmq访问控制试坑篇
访问控制我理解就是两层,第一层是Virtual host,相当于一个个独立主机 第二层是这个permissions,对照下图权限表 权限表(重要!) 需求 configgure write read ...
- 上位机用USB做虚拟串口,总算抓到一个纯代码的总结了,没有坑的完美解决。
用libUSB来实现自己的驱动+下位机理论速度.=1M字节每秒. 达到极限速度 WINDOWS已经自带虚拟串口驱动,只不过还需要一个Inf文件 方法1:直接下载一个串口inf,来修改文件. 方 ...
- 理解Clip Path
http://www.w3cplus.com/css3/using-making-sense-of-clip-path.html http://www.cnblogs.com/coco1s/p/602 ...
- Win10家庭版Hyper-V出坑(完美卸载,冲突解决以及Device Guard问题)
本文链接:https://blog.csdn.net/hotcoffie/article/details/85043894 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附 ...
- css浮动的"巨坑"与完美解决办法
浮动 1 浮动概念 如果想实现网页中排版布局,比如一行内显示对应的标签元素,可以使用浮动属性.浮动可以实现元素并排. 块转行内日块也可以实现一行显示,不过存在空白折叠现象 float 浮动 属性值 描 ...
- 国人Web前端开发必备干货,一个完美支持IE6在内所有浏览器的CSS框架
摘要: 企户动CSS框架是一个能够完美支持IE6~7在内的所有浏览器的 HTML&CSS 前端框架!给Web开发提供了自适应宽度的百分比多列网格,以及已语义化和结构化的标题.段落.列表.表格. ...
- 如何用HTML5+PhoneGap写个Path项目
最近Path这个应用很火爆,网上也出现了不少仿Path菜单的项目.即使在原生APP里边,Path的效果也是非常赞的.我突然想,Web APP是不是也能做出类似Path那样的效果呢?于是就有了OPath ...
- vue 单页应用中微信支付的坑
vue 单页应用中微信支付的坑 标签(空格分隔): 微信 支付 坑 vue 场景 在微信H5页面(使用 vue-router2 控制路由的 vue2 单页应用项目)中使用微信 jssdk 进行微信支付 ...
随机推荐
- 面向Internet的编程
面向Internet的编程 1994年秋天我返回工作时,这个公司的景象已经完全改变.他们决定Oak语言——跨平台的.安全的.易传输的代码——时理想的面向Internet的语言.同时他们在制作名为Web ...
- Spring4 MVC ContentNegotiatingViewResolver多种输出格式实例
本文演示支持多种输出格式,这里 Spring4 MVC应用程序使用了 Spring ContentNegotiatingViewResolver .我们将生成应用程序输出XML,JSON,PDF,XL ...
- 优先队列——二项队列(binominal queue)
[0]README 0.1) 本文文字描述部分转自 数据结构与算法分析, 旨在理解 优先队列——二项队列(binominal queue) 的基础知识: 0.2) 本文核心的剖析思路均为原创(inse ...
- Mysql中查看每个IP的连接数
) as ip , count(*) from information_schema.processlist group by ip;
- Unity3D学习笔记——NGUI之UIScrollBar
UIScrollBar:这个组件可以用于创建滚动条. 效果图如下: 一:使用步骤 1.这个组件和UISlider很像,也是由三部分组成. 2.首先创建一个Sprite用于组件的背景色. 3.创建第二个 ...
- hdu 4005(边双连通)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4005 思路:首先考虑边双连通分量,如果我们将双连通分量中的边删除,显然我们无法得到非连通图,因此要缩点 ...
- linux 学习笔记1
1.IDE硬盘 /dev/hd[a-d] IDE1 主 /dev/hda 从 /dev/hdb IDE2 主 ...
- JSON和JSONP的差别,以及用法
1. 场景 在拉京东城市选择的基础数据时候,遇到被server拒绝的情况,也就是ajax跨域问题 2. json和jsonp 说的直白一点.在我们做ajax异步的一些功能的时候,一定会或多或少的遇到两 ...
- bin/mysqld: error while loading shared libraries: libnuma.so.1: 安装mysql
如果安装mysql出现了以上的报错信息.这是却少numactl这个时候如果是Centos就yum -y install numactl就可以解决这个问题了. ubuntu的就sudo apt-get ...
- PHP 可以获取客户端哪些访问信息
php是一种弱类型的程序语言,但是最web的 在程序语言中有系统全局函数: $_SERVER <?php echo "".$_SERVER['PHP_SELF'];#当前正在 ...