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

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

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

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

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

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

一、border-radius

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

div{  border-radius: 20px;}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

二、伪元素+border-radius

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

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

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

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

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

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

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

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

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

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

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

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

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

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

三、径向渐变

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

四、优缺点总结

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

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

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

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

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

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

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

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

标签:
  • 热门焦点
  • vivo TWS Air开箱体验:真轻 臻好听

    在vivo S15系列新机的发布会上,vivo的最新款真无线蓝牙耳机vivo TWS Air也一同发布,本次就这款耳机新品给大家带来一个简单的分享。外包装盒上,vivo TWS Air保持了vivo自家产
  • 分享六款相见恨晚的PPT模版网站, 祝你做出精美的PPT!

    1、OfficePLUSOfficePLUS网站旨在为全球Office用户提供丰富的高品质原创PPT模板、实用文档、数据图表及个性化定制服务。优点:OfficePLUS是微软官方网站,囊括PPT模板、Word模
  • 本地生活这块肥肉,拼多多也想吃一口

    出品/壹览商业 作者/李彦编辑/木鱼拼多多也看上本地生活这块蛋糕了。近期,拼多多在App首页“充值中心”入口上线了本机生活界面。壹览商业发现,该界面目前主要
  • 中国家电海外掘金正当时|出海专题

    作者|吴南南编辑|胡展嘉运营|陈佳慧出品|零态LT(ID:LingTai_LT)2023年,出海市场战况空前,中国创业者在海外纷纷摩拳擦掌,以期能够把中国的商业模式、创业理念、战略打法输出海外,他们依
  • 腾讯VS网易,最卷游戏暑期档,谁能笑到最后?

    作者:无锈钵来源:财经无忌7月16日晚,上海1862时尚艺术中心。伴随着幻象的精准命中,硕大的荧幕之上,比分被定格在了14:12,被寄予厚望的EDG战队以绝对的优势战胜了BLG战队,拿下了总决
  • ESG的面子与里子

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之三伏大幕拉起,各地高温预警不绝,但处于厄尔尼诺大“烤”之下的除了众生,还有各大企业发布的ESG报告。ESG是“环境保
  • 半导体需求下滑 三星电子DS业务部门今年营业亏损预计超10万亿韩元

    7月17日消息,据外媒报道,去年下半年开始的半导体需求下滑,影响到了三星电子、SK海力士、英特尔等诸多厂商,营收明显下滑,部分厂商甚至出现了亏损。作为
  • 机构称Q2全球智能手机出货量同比下滑11% 苹果份额依旧第2

    7月20日消息,据外媒报道,研究机构的报告显示,由于需求下滑,今年二季度全球智能手机的出货量,同比下滑了11%,三星、苹果等主要厂商的销量,较去年同期均有下
  • 微软发布Windows 11新版 引入全新任务栏状态

    近日,微软发布了Windows 11新版,而Build 22563更新主要引入了几周前曝光的平板模式任务栏等,系统更流畅了。更新中,Windows 11加入了专门针对平板优化的任务栏
Top