使用 CSS 制作丝带效果

发表于 2年以前  | 总阅读数:1045 次

你注意过网站上那些漂亮的丝带效果吗?它们可以用来提醒用户关注一些新特性或者大事件。这个效果很棒,不过对于很多开发者来说,创建这种效果却并不简单。

网上有很多现成的组件,很容易就能找到开箱即用的代码,不过很难对它们做自定义的修改。开发者还需要做很多调试工作并处理报错,直到它们满足需求为止。

本文会介绍如何使用 CSS 创建两种不同类型的丝带效果,使用这种方式就不再需要浪费时间去一直调试了。

这是我们将要创建的效果:

旋转丝带 & 折叠丝带

下面是两种丝带效果的完整代码,看得出来它们非常简洁:

点击此处在 CodePen 查看完整代码。

  <div class="box">
    <div class="ribbon-2">Folded Ribbon</div>
  </div>
  <div class="ribbon-1 left">Rotated Ribbon</div>
  <div class="ribbon-1 right">Rotated Ribbon</div>
  .ribbon-1 {
    position: fixed;
    background: #08769b;
    box-shadow: 0 0 0 999px #08769b;
    clip-path: inset(0 -100%);
  }
  .left {
    inset: 0 auto auto 0;
    transform-origin: 100% 0;
    transform: translate(-29.3%) rotate(-45deg);
  }
  .right {
    inset: 0 0 auto auto;
    transform-origin: 0 0;
    transform: translate(29.3%) rotate(45deg);
  }

  .ribbon-2 {
    --f: 10px; /* 控制折叠部分*/
    --r: 15px; /* 控制丝带形状 */
    --t: 10px; /* 上方偏移距离 */

    position: absolute;
    inset: var(--t) calc(-1*var(--f)) auto auto;
    padding: 0 10px var(--f) calc(10px + var(--r));
    clip-path:
      polygon(0 0,100% 0,100% calc(100% - var(--f)),calc(100% - var(--f)) 100%,
        calc(100% - var(--f)) calc(100% - var(--f)),0 calc(100% - var(--f)),
        var(--r) calc(50% - var(--f)/2));
    background: #BD1550;
    box-shadow: 0 calc(-1*var(--f)) 0 inset #0005;
  }

  .box {
    max-width:500px;
    height:200px;
    margin:50px auto 0;
    background:lightblue;
    position:relative;
  }

  html {
  color: #fff;
  line-height: 1.3em;
  font-family: sans-serif;
  font-size: 25px;
}

如何创建旋转丝带效果

这种丝带通常用来在屏幕顶部展示固定的信息,当然也可以用在页面元素上。

为了理解旋转丝带的创建过程,我们来看下面的步骤示意图:

旋转丝带实现步骤示意图

首先,将丝带元素置于屏幕左上角,红色边框表示屏幕(或者想要在其上添加丝带的页面元素)的边界。

.ribbon {
  position: fixed;
  inset: 0 auto auto 0;
  background: #08769b;
}

目前没什么复杂的。也许你不太了解 inset 属性,它其实是 toprightbottomleft 属性的简写。

接下来,将元素向左偏移:translate(-29.3%)

之后,旋转元素:rotate(-45deg),现在完整代码如下:

.ribbon {
  position: fixed;
  inset: 0 auto auto 0;
  background: #08769b;
  transform-origin: 100% 0; /* 或 top right */
  transform: translate(-29.3%) rotate(-45deg);
}

也许你会很好奇,这个 29.3% 是怎么得来的?它的计算公式为:100% * (1 - cos(45deg))

这里就不做枯燥的数学解释了,总之结果就是旋转之后完美地放置了这个元素(它的左上角和右上角正好处于边界位置)。

你可能还注意到了 transform-origin: top right,这个步骤是将旋转的参考点指定为右上角。

现在元素已经正确地放置了,还需要填充边界的空白。我用一个很大的阴影(box-shadow)来实现,在示意图中用绿色来表示以便区分,实际上它的颜色应该和背景色(background)一致。

接着需要裁切这个阴影,让它只显示左右两边的部分。我会用到 clip-pathinset(0 -100%) 表示将上下两边的阴影裁切掉(值为 0),只显示左右两边(值为 -100%)。

这里的 999px 也可以是别的值,只要它足够大,比如 100vmax——能确保正确显示出左右两边的阴影就行。

现在可以看到最终结果了,其实还有一些溢出的阴影,但是由于元素放在了屏幕左上角边界,所以没人看得见。

如果想把丝带用在页面中的元素上,别忘了给它的父元素设置 overflow: hidden,还要把 fixed 改成 absolute

最终代码如下:

.ribbon-1 {
  position: fixed;
  inset: 0 auto auto 0;
  background: #08769b;
  transform-origin: 100% 0;
  transform: translate(-29.3%) rotate(-45deg);
  box-shadow: 0 0 0 999px #08769b;
  clip-path: inset(0 -100%);
}

我们只用了 7 个样式声明就实现了旋转丝带效果。我们的代码是通用的,并不依赖于其中的文字内容。不论丝带中的内容是什么,它都能正确地展示,甚至可以展示多行文本。

想要把丝带放在右上角的话,只需要修改几个属性值。更好的做法是使用两个样式来分别控制:

.ribbon-1 {
  position: fixed;
  background: #08769b;
  box-shadow: 0 0 0 999px #08769b;
  clip-path: inset(0 -100%);
}
.left {
  inset: 0 auto auto 0; /* top 和 left 的值为 0 */
  transform-origin: 100% 0; /* 或 top right */
  transform: translate(-29.3%) rotate(-45deg);
}
.right {
  inset: 0 0 auto auto; /* top 和 right 的值 0 */
  transform-origin: 0 0; /* 或 top left */
  transform: translate(29.3%) rotate(45deg);
}

我觉得上面的代码是自解释的,.left.right 两个样式之间的区别也不难理解。

如何创建折叠丝带

同样的,一起来看示意图:

折叠丝带实现步骤示意图

首先,将元素放置在父元素的右边:

.ribbon-2 {
  --t: 10px; /* 上方偏移距离 */

  position: absolute;
  inset: var(--t) 0 auto auto;
  padding:0 10px;
  background: #BD1550;

}

我定义了一个变量来控制元素上方的偏移距离,以便通过这个变量来调整丝带的位置。因为用到了 position: absolute,所以别忘了给丝带的父元素指定 position: relative

我还在左右两边增加了一些内边距(padding),这里指定的 10px 并没有什么特殊含义——你想指定其他值也可以。

现在要引入另一个变量来控制折叠的部分,我用这个变量来定义一个内嵌的阴影:box-shadow: 0 calc(-1*var(--f)) 0 #0005

正如你在上图中看到的,这个阴影在元素底部生成了一个半透明的黑色色块,高度由 --f 变量指定。我增加了底部内边距,留出展示阴影的空间:padding: 0 10px var(--f)

接着,继续使用 --f 变量,将丝带往右偏移:把 right:0 更改为 right: calc(-1*var(--f))

现在代码如下:

.ribbon-2 {
  --t: 10px; /* 上方偏移距离 */
  --f :10px /* 控制折叠部分 */

  position: absolute;
  inset: var(--t) calc(-1*var(--f)) auto auto; /* right 属性合并到这里了*/
  padding:0 10px var(--f);
  background: #BD1550;
  box-shadow: 0 calc(-1*var(--f)) 0 inset #0005;
}

代码看起来可能有点奇怪(实现的效果也是),不过下一步我们会创建出最终的形状,到时一切就都能说得通了。

最后一步,我们要引入 clip-path 来裁切元素。我加入了一个变量 --r 来控制丝带箭头的形状。

在加入 clip-path 之前,首先增加左内边距,为箭头形状留出充足空间:

padding: 0 10px var(--f) calc(10px + var(--r));
  • 上内边距为 0
  • 右内边距为 10px(一个随机值)
  • 下内边距由 --f 指定
  • 左内边距为 10px(与右内边距相同)与变量 --r 的值之和

现在加入 clip-path,下图可以帮助我们理解如何通过裁切路径得到最终的形状。

裁切路径示意图

路径由 7 个点组成,从点(1) 开始,跟随箭头方向,可以得到以下代码:

clip-path: polygon(
  0 0,  /* (1) */
  100% 0, /* (2) */
  100% calc(100% - var(--f)), /* (3) */
  calc(100% - var(--f)) 100%, /* (4) */
  calc(100% - var(--f)) calc(100% - var(--f)), /* (5) */
  0 calc(100% - var(--f)), /* (6) */
  var(--r) calc(50% - var(--f)/2) /* (7) */
)

如果不熟悉 clip-path 也无需担心——虽然看着可能有点陌生。你并不需要操作这个路径,只需要改动 CSS 变量来控制形状就行了。

当然,试着改动一些数值来调整路径能够帮助你更好地理解它的原理。

完工了。最终代码如下:

.ribbon-2 {
  --f: 10px; /* 控制折叠部分*/
  --r: 15px; /* 控制丝带形状 */
  --t: 10px; /* 上方偏移距离 */

  position: absolute;
  inset: var(--t) calc(-1*var(--f)) auto auto;
  padding: 0 10px var(--f) calc(10px + var(--r));
  clip-path:
    polygon(0 0,100% 0,100% calc(100% - var(--f)),calc(100% - var(--f)) 100%,
      calc(100% - var(--f)) calc(100% - var(--f)),0 calc(100% - var(--f)),
      var(--r) calc(50% - var(--f)/2));
  background: #BD1550;
  box-shadow: 0 calc(-1*var(--f)) 0 inset #0005;
}

可以通过调整变量数值来获取不同的效果:

与旋转丝带类似,我们也可以通过修改几个属性值,从而将丝带位置从右边移到左边——不过这里我就不给出代码了,留给你自己去尝试。

尝试理解需要调整的各个参数(尤其是 clip-path)是很好的做法。

总结

现在你学会了如何使用 CSS 制作漂亮的丝带效果了。

我还写了另外一篇关于制作丝带效果的文章,有兴趣的话可以看看。其中详细介绍了如何制作旋转的折叠丝带——它结合了本文介绍的两种效果。

感谢阅读!

本文由哈喽比特于2年以前收录,如有侵权请联系我们。
文章来源:https://mp.weixin.qq.com/s/W1GLC-fFitqrSFDmTMQwFA

 相关推荐

刘强东夫妇:“移民美国”传言被驳斥

京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。

发布于:1年以前  |  808次阅读  |  详细内容 »

博主曝三大运营商,将集体采购百万台华为Mate60系列

日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。

发布于:1年以前  |  770次阅读  |  详细内容 »

ASML CEO警告:出口管制不是可行做法,不要“逼迫中国大陆创新”

据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。

发布于:1年以前  |  756次阅读  |  详细内容 »

抖音中长视频App青桃更名抖音精选,字节再发力对抗B站

今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。

发布于:1年以前  |  648次阅读  |  详细内容 »

威马CDO:中国每百户家庭仅17户有车

日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。

发布于:1年以前  |  589次阅读  |  详细内容 »

研究发现维生素 C 等抗氧化剂会刺激癌症生长和转移

近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。

发布于:1年以前  |  449次阅读  |  详细内容 »

苹果据称正引入3D打印技术,用以生产智能手表的钢质底盘

据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。

发布于:1年以前  |  446次阅读  |  详细内容 »

千万级抖音网红秀才账号被封禁

9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...

发布于:1年以前  |  445次阅读  |  详细内容 »

亚马逊股东起诉公司和贝索斯,称其在购买卫星发射服务时忽视了 SpaceX

9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。

发布于:1年以前  |  444次阅读  |  详细内容 »

苹果上线AppsbyApple网站,以推广自家应用程序

据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。

发布于:1年以前  |  442次阅读  |  详细内容 »

特斯拉美国降价引发投资者不满:“这是短期麻醉剂”

特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。

发布于:1年以前  |  441次阅读  |  详细内容 »

光刻机巨头阿斯麦:拿到许可,继续对华出口

据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。

发布于:1年以前  |  437次阅读  |  详细内容 »

马斯克与库克首次隔空合作:为苹果提供卫星服务

近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。

发布于:1年以前  |  430次阅读  |  详细内容 »

𝕏(推特)调整隐私政策,可拿用户发布的信息训练 AI 模型

据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。

发布于:1年以前  |  428次阅读  |  详细内容 »

荣耀CEO谈华为手机回归:替老同事们高兴,对行业也是好事

9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。

发布于:1年以前  |  423次阅读  |  详细内容 »

AI操控无人机能力超越人类冠军

《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。

发布于:1年以前  |  423次阅读  |  详细内容 »

AI生成的蘑菇科普书存在可致命错误

近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。

发布于:1年以前  |  420次阅读  |  详细内容 »

社交媒体平台𝕏计划收集用户生物识别数据与工作教育经历

社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”

发布于:1年以前  |  411次阅读  |  详细内容 »

国产扫地机器人热销欧洲,国产割草机器人抢占欧洲草坪

2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。

发布于:1年以前  |  406次阅读  |  详细内容 »

罗永浩吐槽iPhone15和14不会有区别,除了序列号变了

罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。

发布于:1年以前  |  398次阅读  |  详细内容 »
 相关文章
Android插件化方案 5年以前  |  237273次阅读
vscode超好用的代码书签插件Bookmarks 2年以前  |  8108次阅读
 目录