画梯形我看行

背景

最近业务有需求需要开发一个梯形的切换标题,当时想着梯形也不是啥奇形怪状的图形,不分分钟拿下。但是仔细看了设计稿感觉还是有挺多细节的。

  1. 梯形之间相互重叠
  2. 梯形拥有自己的边框和内部阴影
  3. 左边梯形是直角梯形
  4. 点击后背景颜色需要变更
  5. 底部边框需要隐藏

实现

这样就可以等到一个宽度300,高度100的等腰梯形了

css 复制代码
.trapezoid {
  width: 200px;
  height: 0;
  border-bottom: 100px solid red;
  border-left: 50px solid transparent;
  border-right: 50px solid transparent;
}

百度还发现一个有意思的属性也可以实现一个等腰梯形

css 复制代码
.trapezoid {
  width: 200px;
  height: 100px;
  background-color: red;
  clip-path: polygon( 25% 0%, 75% 0, 100% 100%,0 100%);
}

但是上面2种方式都没办法满足条件2,一旦实现边框或者需要实现内阴影这个需求,都不得劲;

最后找到一个以前没怎么用到的属性解决了

css 复制代码
.toggle-title {
  position: relative;
  padding: 0;
  text-decoration: none;
  display: inline-block;
  width: 150px;
  height: 50px;
  text-align: center;
  line-height: 50px;
  font-size: 18px;
  color: #099aab;
  font-weight: bold;
  cursor: pointer;
}

.toggle-title::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border: 1px solid #7fcbd3;
  border-bottom: none;
  transform: perspective(1em) scale(1.02, 1.3) rotateX(5deg);
  z-index: -1;
  background: #c1e6ea;
  box-shadow: 0 0 10px #7fcbd3 inset;
  transform-origin: bottom;
  border-radius: 5px 5px 0 0;
  cursor: pointer;
}

相对来说基本手写css就实现了,重点核心就在于perspective这个属性,MDN或者看看文章学习下,发现一个是控制元素纵深效果的一个属性,确实厉害,css真的永远都学不完。

相关推荐
烛阴9 小时前
从0到1掌握盒子模型:精准控制网页布局的秘诀
前端·javascript·css
柚子81613 小时前
color-mix让你秒变调色大神
前端·css
晴殇i14 小时前
CSS Grid 布局中添加分隔线的4种实用方法
前端·css·前端框架
BUG收容所所长17 小时前
揭秘 To-Do List:一个前端小玩具的“幕后玩家”
javascript·css
断竿散人17 小时前
CSS布局完全指南(下)-Flexbox完全征服指南:一维布局的终极解决方案
前端·css
G等你下课20 小时前
被低估的 CSS 核心!盒子模型如何撑起万亿级网页?
前端·css
Hilaku20 小时前
😵‍💫 产品:你能不能让按钮 hover 有个动效?我直接做了个 UI 框架
前端·javascript·css
LuckySusu21 小时前
【CSS篇】display: block、inline 与 inline-block 的区别详解
前端·css
睡不着先生21 小时前
CSS Anchor Positioning:重新定义「锚定定位」的时代来了!
css·html·设计
LuckySusu21 小时前
【CSS篇】CSS 选择器及其优先级详解:掌握样式覆盖的底层逻辑
前端·css