CSS实现一个渐变色的箭头🔜

需求

产品希望在漏斗图的旁边,每一层漏斗边上加上一个渐变色的箭头,效果如下:

实现

网上大部分的箭头实现都是利用一个 div 来实现箭头躯干的矩形部分,再利用其 ::after 伪元素的 border 绘制一个三角形头部。这样会导致渐变的背景无法在两个元素上连贯的过渡。

直接让UI出图?缺点是肉眼可见的模糊,尤其在高分辨率屏、滚轮放大的情况下。

笔者能想到的相关 API 有 background-clipmask,在查阅相关文档的时候发现了下面这个方法: polygon() - CSS: Cascading Style Sheets | MDN (mozilla.org)

文档一点进去就是一个渐变色的箭头,真是踏破铁鞋无觅处,得来全不费工夫。

html 复制代码
<div class="arrow"></div>
CSS 复制代码
.arrow {
  width: 20px;
  height: 100px;
  background-image: linear-gradient(to bottom, red, yellow);
  clip-path: polygon(50% 100%, 0% 85%, 35% 85%, 35% 0%, 65% 0%, 65% 85%, 100% 85%);
}

polygon 方法看起来有一些抽象,其实就是通过在指定元素中,定义若干个顶点,最终裁剪出一个由这些顶点连接起来形成的多边形。其中每一组参数,定义的是这些顶点的相对于元素的位置。最终会裁出该元素位于多边形内的内容,不在clip-path定义的区域内的部分将不会显示。

相关推荐
糕冷小美n10 小时前
elementuivue2表格不覆盖整个表格添加固定属性
前端·javascript·elementui
小哥不太逍遥11 小时前
Technical Report 2024
java·服务器·前端
沐墨染11 小时前
黑词分析与可疑对话挖掘组件的设计与实现
前端·elementui·数据挖掘·数据分析·vue·visual studio code
anOnion11 小时前
构建无障碍组件之Disclosure Pattern
前端·html·交互设计
threerocks11 小时前
前端将死,Agent 永生
前端·人工智能·ai编程
问道飞鱼12 小时前
【前端知识】Vite用法从入门到实战
前端·vite·项目构建
爱上妖精的尾巴12 小时前
8-10 WPS JSA 正则表达式:贪婪匹配
服务器·前端·javascript·正则表达式·wps·jsa
Aliex_git13 小时前
浏览器 API 兼容性解决方案
前端·笔记·学习
独泪了无痕13 小时前
useStorage:本地数据持久化利器
前端·vue.js
程序员林北北13 小时前
【前端进阶之旅】JavaScript 一些常用的简写技巧
开发语言·前端·javascript