html5任意形状按钮,CSS实现8种炫酷按钮

在各种UI组件库大行其道的今天,大家已经很少自己用CSS去实现一些效果了,久而久之CSS的水平也越来越退步,所以有空还是得练练。今天给大家分享8种炫酷按钮的CSS实现。

1. 3D按钮1

1460000019943760?w=640&h=192

现在的主流是扁平化的设计,拟物化的设计比较少见了,所以我们仅从技术角度去分析如何实现这个3D按钮(文中只列出各种实现的关键代码,完整代码请参考CodePen)。

该按钮的立体效果主要由按钮多出的左、下两个侧面衬托出来,我们可以使用box-shadow模拟出这两个侧面:

HTML:

3D Button 1

CSS:

.button-3d-1{

position: relative;

background: orangered;

border: none;

color: white;

padding: 15px 24px;

font-size: 1.4rem;

outline: none;

box-shadow: -6px 6px 0 hsl(16, 100%, 30%);

}

效果:

1460000019943761?w=600&h=180

加了box-shadow之后整体形状有点像了,但是立方体的左上和右下确缺了一块。通过观察我们发现,缺的这两块是三角形的,所以如果我们能构造两个三角形补到这两个角上就行了。用CSS画三角形对大家来说应该是基本操作了,如果还有同学不知道,下面的动画很好的解释了原理(代码参考 Triangle):

1460000019943762?w=400&h=404

我们使用::before和::after伪元素来分别绘制左上、右下的两个三角形,并通过绝对定位将它们固定到两个角落:

CSS:

.button-3d-1::before {

content: "";

display: block;

width: 0;

height: 0;

position: absolute;

top: 0;

left: -6px;

border: 6px solid transparent;

border-right: 6px solid hsl(16, 100%, 30%);

border-left-width: 0px;

}

.button-3d-1::after {

content: "";

display: block;

width: 0;

height: 0;

position: absolute;

bottom: -6px;

right: 0;

border: 6px solid transparent;

border-top: 6px solid hsl(16, 100%, 30%);

border-bottom-width: 0px;

}

接下来,我们需要实现点击时按钮被按下的效果,思路是点击时将按钮正面向左下角移动,同时减少box-shadow的偏移量以达到按钮底部固定不动的效果:

CSS:

.button-3d-1:active {

background: hsl(16, 100%, 40%);

top: 3px;

left: -3px;

box-shadow: -3px 3px 0 hsl(16, 100%, 30%);

}

最后,我们需要重新计算左上、右下两个三角形的尺寸和位置,以适应按下后上下缺口的变小:

CSS:

.button-3d-1:active::before {<

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值