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

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

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

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

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

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

一、border-radius

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

div{  border-radius: 20px;}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

二、伪元素+border-radius

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

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

用代码实现就是4zU28资讯网——每日最新资讯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%);}

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

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

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

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

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

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

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

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

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

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

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

三、径向渐变

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

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

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

用代码实现就是4zU28资讯网——每日最新资讯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;}

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

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

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

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

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

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

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

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

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

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

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

四、优缺点总结

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

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

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

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

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

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

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

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

标签:
  • 热门焦点
  • 6月iOS设备性能榜:M2稳居榜首 A系列只能等一手3nm来救

    没有新品发布,自然iOS设备性能榜的上榜设备就没有什么更替,仅仅只有跑分变化而产生的排名变动,毕竟苹果新品的发布节奏就是这样的,一年下来也就几个移动端新品,不会像安卓厂商,一
  • Rust中的高吞吐量流处理

    作者 | Noz编译 | 王瑞平本篇文章主要介绍了Rust中流处理的概念、方法和优化。作者不仅介绍了流处理的基本概念以及Rust中常用的流处理库,还使用这些库实现了一个流处理程序
  • 之家push系统迭代之路

    前言在这个信息爆炸的互联网时代,能够及时准确获取信息是当今社会要解决的关键问题之一。随着之家用户体量和内容规模的不断增大,传统的靠"主动拉"获取信息的方式已不能满足用
  • 微信语音大揭秘:为什么禁止转发?

    大家好,我是你们的小米。今天,我要和大家聊一个有趣的话题:为什么微信语音不可以转发?这是一个我们经常在日常使用中遇到的问题,也是一个让很多人好奇的问题。让我们一起来揭开这
  • 拼多多APP上线本地生活入口,群雄逐鹿万亿市场

    Tech星球(微信ID:tech618)文 | 陈桥辉 Tech星球独家获悉,拼多多在其APP内上线了“本地生活”入口,位置较深,位于首页的“充值中心”内,目前主要售卖美食相关的
  • 本地生活这块肥肉,拼多多也想吃一口

    出品/壹览商业 作者/李彦编辑/木鱼拼多多也看上本地生活这块蛋糕了。近期,拼多多在App首页“充值中心”入口上线了本机生活界面。壹览商业发现,该界面目前主要
  • 携众多高端产品亮相ChinaJoy,小米带来一场科技与人文的视听盛宴

    7月28日,全球数字娱乐领域最具知名度与影响力的年度盛会中国国际数码互动娱乐展览会(简称ChinaJoy)在上海新国际博览中心盛大开幕。作为全球领先的科
  • 由于成本持续增加,笔记本产品价格预计将明显上涨

    根据知情人士透露,由于材料、物流等成本持续增加,笔记本产品价格预计将在2021年下半年有明显上涨。进入6月下旬以来,全球半导体芯片缺货情况加剧,显卡、处理器
  • 利用职权私自解除被封帐号 Meta开除20多名员工

    11月18日消息,据外媒援引知情人士表示,过去一年时间内,Facebook母公司Meta解雇或处罚了20多名员工以及合同工,指控这些人通过内部系统以不当方式重置用户帐号,其
Top