当前位置: 首页 > news >正文

CSS 实现高频出现的复杂怪状按钮 - 镂空的内凹圆角边框

里面包含了如下这些图形:

你可以在这里看到:CodePen Demo -- CSS Various Button Shapes | CSS 各种造型按钮

接下来几篇文章中,将在上述基础上,额外补充一些在日常设计稿中,常见的,可能出现的更为复杂的几个按钮,本文,我们来尝试实现这个造型:

不镂空的内凹圆角按钮

在文章开头的贴图中,其实是有和这个按钮非常类似的造型:

此造型如果内部无需镂空,整体还是比较简单的,利用background: radial-gradient()径向渐变或者mask,都能比较轻松的实现。

我们快速回顾一下,看这样一个简单的例子:

<div></div>
div { background-image: radial-gradient(circle at 100% 100%, transparent 0, transparent 12px, #2179f5 12px); }

可以得到这样一个图形:

所以,只需控制下background-size,在 4 个角实现 4 个这样的图形即可:

<div class="inset-circle">inset-circle</div>
&.inset-circle { background-size: 70% 70%; background-image: radial-gradient( circle at 100% 100%, transparent 0, transparent 12px, #2179f5 13px ), radial-gradient( circle at 0 0, transparent 0, transparent 12px, #2179f5 13px ), radial-gradient( circle at 100% 0, transparent 0, transparent 12px, #2179f5 13px ), radial-gradient( circle at 0 100%, transparent 0, transparent 12px, #2179f5 13px ); background-repeat: no-repeat; background-position: right bottom, left top, right top, left bottom; }

借助 mask 实现渐变的内切圆角按钮

如果背景色要求渐变怎么办呢?

假设我们有一张矩形背景图案,我们只需要使用mask实现一层遮罩,利用mask的特性,把 4 个角给遮住即可。

mask的代码和上述的圆角切角代码非常类似,简单改造下即可得到渐变的内切圆角按钮:

<div class="mask-inset-circle">inset-circle</div>
.mask-inset-circle { background: linear-gradient(45deg, #2179f5, #e91e63); mask: radial-gradient( circle at 100% 100%, transparent 0, transparent 12px, #2179f5 13px ), radial-gradient( circle at 0 0, transparent 0, transparent 12px, #2179f5 13px ), radial-gradient( circle at 100% 0, transparent 0, transparent 12px, #2179f5 13px ), radial-gradient( circle at 0 100%, transparent 0, transparent 12px, #2179f5 13px ); mask-repeat: no-repeat; mask-position: right bottom, left top, right top, left bottom; mask-size: 70% 70%; }

这样,我们就得到了这样一个图形:

镂空的内凹圆角边框

但是,如果要求内部是整体镂空,只展示内凹圆角边框,整个复杂度一下就上来了。

上面的方法以及不适用了,原因在于很难利用mask制造一个不规则的内凹圆角形状进行裁剪,因此,我们必须另辟蹊径。

渐变偏移技巧

在 CSS 高阶小技巧 - 角向渐变的妙用! 一文中,我们介绍了渐变一个非常有意思的偏移技巧:

举个例子,下面是角向渐变conic-gradient()的简单介绍:

{ background: conic-gradient(deeppink, yellowgreen); }

从渐变的圆心、渐变起始角度以及渐变方向上来说,是这样的:

划重点:

从图中可以看到,角向渐变的起始圆心点、起始角度和渐变方向为:

  1. 起始点是图形中心,
  2. 默认渐变角度 0deg 是从上方垂直于圆心的
  3. 渐变方向以顺时针方向绕中心实现

当然,我们也可以控制角向渐变的起始角度以及角向渐变的圆心

稍微改一下上述代码:

{ background: conic-gradient(from 270deg at 50px 50px, deeppink, yellowgreen); }

效果如下:

我们改变了起始角度以及角向渐变的圆心

了解了这个之后。我们基于上述的图形,重新绘制一个图形:

div { margin: auto; width: 200px; height: 200px; background: conic-gradient(from 270deg at 50px 50px, deeppink 0%, deeppink 90deg, transparent 90deg, transparent 360deg); border: 1px solid #000; }

效果如下:

起始角度以及角向渐变的圆心没有改变,但是只让前 90deg 的图形为粉色,而后 270deg 的图形,设置为了透明色。

我们利用角向渐变,在图像内部,又实现了一个小的矩形!

接下来,我们再给上述图形,增加一个background-position: -25px, -25px

div { margin: auto; width: 200px; height: 200px; background: conic-gradient(from 270deg at 50px 50px, deeppink 0%, deeppink 90deg, transparent 90deg, transparent 360deg); background-position: -25px -25px; border: 1px solid #000; }

这样,我们就神奇的得到了这样一个图形:

为什么会有这样一种现象?如果我们在代码中加入background-repeat: no-repeat

div { width: 200px; height: 200px; background: conic-gradient(from 270deg at 50px 50px, deeppink 0%, deeppink 90deg, transparent 90deg, transparent 360deg); background-position: -25px -25px; background-repeat: no-repeat; border: 1px solid #000; }

那么就只会剩下左上角一个角:

因此,这里实际上利用了渐变图形默认会 repeat 的特性,实际上是这么个意思:

http://www.jsqmd.com/news/1107145/

相关文章:

  • 集成学习实战:从偏差-方差权衡到可演进的工业级预测系统
  • Mi-Create:5分钟学会零代码制作小米穿戴表盘的终极指南
  • 《我的机器人女友:代号夜莺》
  • Prisma和TypeORM的区别
  • Biotinyl-Preangiotensiongen (1-14) (human) ;Bio-DRVYIHPFHLVIHN
  • 科研学术界的“KFC”!GPT-5.6 四个技巧轻松拿捏论文选题
  • DayZ终极单机离线模式:5分钟快速安装完整免费生存体验
  • 旧物利用 - 将机顶盒改造为一台Linux开发机!
  • 2026以云筑盾,护航数字化发展新时代网络安全建设之路
  • 个人网站恶意流量防御实战:从监控到架构的四层防护体系
  • AI读心术:破解沉默中的命运密码
  • 别踩,2026做视频总结的成本误区,我整理了亲测实操省钱经验
  • Triton模型服务工程化:高并发AI推理的生产落地实践
  • 柔韧智能:AI如水般的未来存在
  • ⁉️微软MOS2016版本认证停考的重要通知
  • Windows系统优化新选择:开源清理工具让你的电脑重获新生
  • 从数据录入到获客:解析中坻沐客同普通CRM跟进区别
  • 把 Linux 想象成一座城市,一切突然清晰了
  • AI 电动农业机械 植物生长灯智能功率 MOSFET 精准选型方案
  • 慢智能:AI的优雅减速时代
  • 知识分享|软件登记测试报告主要用途,双软认定主要材料!
  • DXVK 2.7.1:Linux游戏图形API转换层的异步架构与性能优化深度解析
  • 丽兴金庄珠宝行创办人陈三弟荣登《祖国》杂志封面人物
  • config.json 文件是固定名称,存储描述信息,比如需要的变量名称、描述等。下面是一个 completion 类型的插件配置文件示例,除了一些跟提示模板相关的配置,还有一些聊天的配置,如最大 t
  • 王中王指标中线和长线波段指标
  • 液压系统的溢流阀溢流导致能耗高解决方案
  • 元脉网络发布AIGC存储网络解决方案
  • WebPKI证书验证库:原理、选型与Python实战封装
  • 2026怎么选成都展厅设计公司?最新口碑实测推荐
  • 测试专用111