CSS 实现切角效果

简介: CSS 实现切角效果
欢迎关注我的公众号: 前端侦探


最近项目中看到这样的一个切角效果,如下所示


image.png

就是一个正常的矩形,然后被“切”了一块,而且是沿着右上角切的。那么,这种布局如何实现呢?


一、自适应方式


这种布局一般有两种自适应方式,当然具体需要哪种可以根据实际设计师需求


1. 固定距离


无论宽高怎么变化,切角距离顶部的距离是固定的,如下


image.png

2. 固定角度


无论宽高怎么变化,切角与顶部的夹角是固定的,如下


image.png


下面具体来看这两种布局的实现


二、固定距离的切角


固定距离的比较好实现,只需要借助 clip-path就可以了。假设距离顶部的距离是20px,那么四个点的坐标是


image.png

代码实现就是

div{
  clip-path: polygon(0 20px, 100% 0, 100% 100%, 0 100%);
}


这样就得到了一个固定距离的切角


image.png

三、固定角度的切角


这个稍微复杂一点。起初,我以为简单的线性渐变就能实现,比如

div{
  background: linear-gradient(-30deg, #B89DFF 80%, transparent 0);
}


实时效果如下


image.png

可以看到,角度虽然是固定的,但是切角不会紧贴右上角,原因是线性渐变的起始点是沿着角度与之垂直的最远距离,如下所示(截图取自 MDN 官网)


image.png

所以并不能保证切角的固定相交位置,比较适合那种小切角场景。


那还有其他方式吗?当然也是有的


提到角度,除了线性渐变,还能想到锥形渐变conic-gradient),可以以某一点绘制锥形图案。假设固定角度是20度,示意如下


image.png

那么,锥形渐变的角度就是 250°(270 - 20),代码实现如下

div{
  background: conic-gradient(#B89DFF 250deg, transparent 0);
}


效果如下


image.png

因为锥形渐变默认中心点是容器的中点,我们需要移到右上角,可以通过at来指定位置,如下

div{
  background: conic-gradient(at 100% 0, #B89DFF 250deg, transparent 0);
}


这样就得到了一个固定角度的切角


image.png

四、总结一下


以上就是这类布局的两种实现方案,主要用到了clip-pathconic-gradient,下面总结一下


  1. clip-path 可以根据坐标点裁剪矩形
  2. linear-gradient 也能实现切角效果,但并不能紧贴右上角
  3. conic-gradient 可以实现实现任意角度的锥形,同时能指定中心点位置


当然不仅仅局限于此,很多不规则布局都可以朝这个方向思考🤔最后,如果觉得还不错,对你有帮助的话,欢迎点赞、收藏、转发❤❤❤


欢迎关注我的公众号: 前端侦探
相关文章
|
前端开发 JavaScript 开发者
利用 SplitingJS 配合 CSS 实现文字"蠕动"效果
利用 SplitingJS 配合 CSS 实现文字"蠕动"效果
373 2
|
前端开发 JavaScript
HTML+CSS+JAVASCRIPT实现——情人节表白情书
本文主要介绍如何使用HTML三件套来实现制作一封情人节表白情书,富含情谊与爱,打动女生的心灵
739 2
HTML+CSS+JAVASCRIPT实现——情人节表白情书
|
前端开发 容器
面试官:请使用 CSS 实现自适应正方形
面试官:请使用 CSS 实现自适应正方形
501 0
面试官:请使用 CSS 实现自适应正方形
|
JavaScript 前端开发
CSS进阶向--配合Vue动态样式实现“超炫酷”圆环菜单
CSS进阶向--配合Vue动态样式实现“超炫酷”圆环菜单
880 2
CSS进阶向--配合Vue动态样式实现“超炫酷”圆环菜单
|
前端开发 JavaScript
CSS进阶向--纯css实现流光边框(二)
CSS进阶向--纯css实现流光边框(二)
2261 1
CSS进阶向--纯css实现流光边框(二)
|
前端开发 JavaScript 程序员
CSS进阶向--纯css实现流光边框
CSS进阶向--纯css实现流光边框
1980 0
Html+Css实现——时间轴日志
本篇文章,主要讲解一下如何创建一个精美的时间轴日志页面,其中代码里具体的日志内容部分需要自行更改哦!
381 1
Html+Css实现——时间轴日志
|
前端开发
纯CSS实现跑马灯效果
又是一个安静的晚上,又是没有灵感的一天,又只能去逛逛codepen。看到一个流光的边框效果,我就想如何通过自己的方式来现这样一个效果。 突然又想起路边夜市的招牌,不就是一个流光效果加一个广告词吗。这下我的兴趣一下就激发起来了。
|
前端开发 容器
我已经说了5种css居中实现的方式了,面试官竟然说还不够?
这是一篇关于居中对齐方式的总结 开篇之前,先问一下大家都知道几种居中的实现方式? 面试时答出来两三个就不错了,就怕面试官还让你继续说。今天就来总结一下这些居中的方式 使用flex布局设置居中。 使用flex 时也能通过给子项设置margin: auto实现居中。 使用绝对定位的方式实现水平垂直居中。 使用grid设置居中。 使用grid时还能通过给子项设置margin: auto实现居中。 使用tabel-cell实现垂直居中。 还有一种不常用的方法实现垂直居中。 最后还有一种奇葩的方法。容器设置position: relative。孩子设置 top、left、bottom、right都设
170 0
我已经说了5种css居中实现的方式了,面试官竟然说还不够?
|
前端开发
HTML+CSS实现商品介绍模考(以Apple14为案例)
本文以最通俗易懂的语言为读者提供一个经典CSS小案例,商品介绍模块,并且结合时事,以Apple14为案例进行讲解。
181 0
HTML+CSS实现商品介绍模考(以Apple14为案例)