当前位置:首页 > 科技  > 软件

CSS 实现弧形卡片的三种方式

来源: 责编: 时间:2023-12-04 17:26:56 344观看
导读在平时开发中,有时候会碰到下面这种“弧形”样式,主要分为“内凹”和“外凸”两种类型,如下图片该如何实现呢?或者想一下,有哪些 CSS 属性和“弧形”有关?下面介绍 3 种方式,一起看看吧一、border-radius通常情况下,我们用bor

在平时开发中,有时候会碰到下面这种“弧形”样式,主要分为“内凹”和“外凸”两种类型,如下iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

该如何实现呢?或者想一下,有哪些 CSS 属性和“弧形”有关?下面介绍 3 种方式,一起看看吧iLb28资讯网——每日最新资讯28at.com

一、border-radius

通常情况下,我们用border-radius都是这样iLb28资讯网——每日最新资讯28at.com

div{  border-radius: 20px;}

这样表示 4 个角都是圆角,并且是标准的正圆iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

其实,border-radius还支持斜杠的写法,比如iLb28资讯网——每日最新资讯28at.com

div{  border-radius: 20px / 10px;}

这表示,圆角是一个x半径为20px,y半径为10px的椭圆,如下iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

放大来看,其实是这样的iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

进一步,我们将x半径设置成50%,这样就能得到一个完整的弧形了iLb28资讯网——每日最新资讯28at.com

div{  border-radius: 50% / 20px;}

效果如下iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

这样就得到了“外凸”的弧形了,是不是很容易?iLb28资讯网——每日最新资讯28at.com

至于“内凹”弧形,单纯的border-radius表示无能为力,可以看接下来的方式iLb28资讯网——每日最新资讯28at.com

二、伪元素+border-radius

这个其实大多数同学都能想到的方式,一个矩形和一个椭圆组合起来,不就是一个弧形卡片了吗?原理非常简单iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

用代码实现就是iLb28资讯网——每日最新资讯28at.com

div{  position: relative;}div::after{  content: '';  position: absolute;  width: 100%;  height: 20px;  border-radius: 100%;  background: inherit; /* 继承父级背景 */  bottom: 0;  left: 50%;  transform: translate(-50%,50%);}

效果如下(虚线表示伪元素的边缘)iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

用伪元素的好处是,可以随意控制弧度的「大小」和「位置」,这个是border-radius所不能比的iLb28资讯网——每日最新资讯28at.com

通过overflow:hidden裁剪多余部分,可以得到一个边缘比较“锋利”的弧形,如下所示iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

另外,用伪元素还能实现“内凹”的效果,不过这需要反过来思考,什么意思呢?之前是给伪元素加的背景,现在需要加在伪元素的外围,这里用box-shadow实现,原理如下iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

用代码实现就是iLb28资讯网——每日最新资讯28at.com

div{  background: none;  overflow: hidden;}div::after{  content: '';  background: none;  box-shadow: 0 0 0 9999vh #FFE8A3; /*足够大的阴影*/  z-index: -1;}

效果如下(虚线表示伪元素的边缘)iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

三、径向渐变

提到圆弧,还可以想到径向渐变,没错,这里通过径向渐变也能轻易实现弧形卡片效果。iLb28资讯网——每日最新资讯28at.com

先来看“外凸”的,其实思路和伪元素一样,先拆分,一个椭圆和一个矩形,对应的就是径向渐变(radial-gradient)和线性渐变(linear-gradient),如下iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

用代码实现就是iLb28资讯网——每日最新资讯28at.com

div{  background:     radial-gradient(closest-side, #9747FF 100%,transparent 0) center bottom/100% 20px no-repeat,    linear-gradient(#FFE8A3, #FFE8A3) 0 0/100% calc(100% - 10px) no-repeat;}

效果如下(紫色部分是径向渐变)iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

再来看“内凹”的弧形,其实也和伪元素思路类似,只不过这里需要绘制一个足够大的渐变,从透明到纯色的径向渐变,示意如下iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

调整好渐变中心点,用代码实现就是iLb28资讯网——每日最新资讯28at.com

div{  background: radial-gradient(50% 10px at center bottom, transparent 100%,#FFE8A3 0) center bottom;}

效果如下(全部都是径向渐变绘制)iLb28资讯网——每日最新资讯28at.com

图片图片iLb28资讯网——每日最新资讯28at.com

当然你也可以随意改变径向的弧度和大小,来实现各种不同的效果。iLb28资讯网——每日最新资讯28at.com

以上所有demo都可以查看以下在线链接iLb28资讯网——每日最新资讯28at.com

  • CSS radius layout (juejin.cn)[1]
  • CSS radius layout (codepen.io)[2]

四、优缺点总结

以上就是本文的全部内容了,共介绍了 3 种不同的方式,下面总结一下各自优缺点iLb28资讯网——每日最新资讯28at.com

  1. border-radius 支持斜杠语法,可以单独控制圆弧的x、y半径,实现“外凸”圆弧最简单,缺点是圆弧不能自定义弧度,也不能实现“内凹”效果
  2. 伪元素最符合常规思维,可以解决以上问题,缺点是需要占用伪元素,略微麻烦
  3. 渐变实现和伪元素拼接思路类似,缺点是语法复杂,需要熟练掌握渐变语法

[1]CSS radius layout (juejin.cn): https://code.juejin.cn/pen/7307633420241534985iLb28资讯网——每日最新资讯28at.com

[2]CSS radius layout (codepen.io): https://codepen.io/xboxyan/pen/RwveByxiLb28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-37684-0.htmlCSS 实现弧形卡片的三种方式

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Python 数据库操作模块大揭秘:带你轻松掌握这六种常见模块!

下一篇: 2023软件架构和设计的趋势

标签:
  • 热门焦点
  • 6月安卓手机好评榜:魅族20 Pro蝉联冠军

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年6月1日至6月30日,仅限国内市场。第一名:魅族20 Pro好评率:95%5月份的时候魅族20 Pro就是
  • 5月安卓手机好评榜:魅族20 Pro夺冠

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年5月1日至5月31日,仅限国内市场。第一名:魅族20 Pro好评率:97.50%不得不感慨魅族老品牌还
  • 线程通讯的三种方法!通俗易懂

    线程通信是指多个线程之间通过某种机制进行协调和交互,例如,线程等待和通知机制就是线程通讯的主要手段之一。 在 Java 中,线程等待和通知的实现手段有以下几种方式:Object 类下
  • 在线图片编辑器,支持PSD解析、AI抠图等

    自从我上次分享一个人开发仿造稿定设计的图片编辑器到现在,不知不觉已过去一年时间了,期间我经历了裁员失业、面试找工作碰壁,寒冬下一直没有很好地履行计划.....这些就放在日
  • 猿辅导与新东方的两种“归途”

    作者|卓心月 出品|零态LT(ID:LingTai_LT)如何成为一家伟大企业?答案一定是对“势”的把握,这其中最关键的当属对企业战略的制定,且能够站在未来看现在,即使这其中的
  • iQOO 11S新品发布会

    iQOO将在7月4日19:00举行新品发布会,推出杭州亚运会电竞赛事官方用机iQOO 11S。
  • 3699元!iQOO Neo8 Pro顶配版今日首销:1TB UFS 4.0同价位唯一

    5月23日,iQOO推出了全新的iQOO Neo8系列,包含iQOO Neo8和iQOO Neo8 Pro两个版本,其中标准版搭载高通骁龙8+,而Pro版更是首发搭载了联发科天玑9200+旗舰
  • iQOO Neo8 Pro真机谍照曝光:天玑9200+和V1+旗舰双芯加持

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
  • OPPO K11搭载长寿版100W超级闪充:26分钟充满100%

    据此前官方宣布,OPPO将于7月25日也就是今天下午14:30举办新品发布会,届时全新的OPPO K11将正式与大家见面,将主打旗舰影像,和同档位竞品相比,其最大的卖
Top