html的自定义按钮,「HTML+CSS」--自定义按钮样式【003】

这篇博客详细介绍了如何使用HTML和CSS实现自定义按钮的样式,包括鼠标悬停和点击时的过渡效果。通过使用伪类`:before`、渐变背景色以及CSS的`transition`属性,创建了从上至下的覆盖效果。同时,文中还解释了关键样式的选择和设置,如设置`z-index`、`border-radius`和`box-shadow`,以及解决点击按钮后出现边框的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

效果展示

9c906bf880f711e606baf85a4873b97e.png思路

上面效果可以概括为:鼠标未停留时:青色(渐变)背景,正中文字为白色,button四角做了圆角处理

鼠标停留时:浅青色背景从上至下,依次覆盖button

鼠标离开button时:浅青色背景从上至下,依次消失,button逐渐恢复原样

根据效果图可以得出实现的一些思路:初始状态,设置button背景为渐变青色,中间文字为白色,做圆角、阴影处理

初看有两个过渡效果,其实是可以用一个元素的过渡transition实现的

这里我们就利用button的::before伪类元素来实现

将::before设置为绝对定位,初始位置为左下角(右下也是可以的),其中width设置为100%,height为0

触发hover时,height设置为100%,top设置为0 (记住这里的关键点top:0)

还有就是,button和::before的背景颜色需要有所深浅变化

这里使用的渐变色:深青(渐变):linear-gradient(315deg, #89d8d3 0%, #03c8a8 74%);

浅青(渐变):linear-gradient(315deg, #4dccc6 0%, #96e4df 74%);Demo代码

HTMLDocumentHaihong Pro

CSShtml,body{

margin: 0;

height: 100%;

}

body{

display: flex;

justify-content: center;

align-items: center;

}

.btn{

width: 390px;

height: 120px;

background:linear-gradient(315deg, #89d8d3 0%, #03c8a8 74%);

border: none;

border-radius: 10px;

font-family: 'Lato', sans-serif;

font-weight: 500;

font-size: 48px;

color: #fff;

box-shadow: inset 2px 2px 2px 0px rgba(255, 255, 255, .5),

7px 7px 20px 0px rgba(0, 0, 0, .1),

4px 4px 5px 0px rgba(0, 0, 0, .1);

outline: none;

position: relative;

z-index: 0;

}

.btn::before{

position:absolute;

content: '';

left: 0;

bottom:0;

width: 100%;

height: 0;

transition: all 0.3s ease;

border-radius: 10px;

background: linear-gradient(315deg, #4dccc6 0%, #96e4df 74%);

z-index: -1;

}

.btn:hover::before{

top: 0;

height: 100%;

}

.btn:active{

top: 2px;

}疑点详解

1.为什么触发hover时,除了设置height:100%外,还需要设置top:0呢?上面效果图原理是怎样呢?

为了便于观察,我们将::before的初始状态显示出来

81da3ca66d652d2fb8d6422998593375.png

b2f0f76a7635a0fe12aac4baeb17014b.png

初始时,before的位置是在左下角(bottom:0  left:0)

触发hover时,如果只是设置heigth:100%,产生的效果如下:

f4c26913b635b10fdb93e82936d312bb.png

如果此时立即将位置改为左上角(top:0 left:0),就会产生从上至下的效果:

703ba1de6ec6079e0ed143fe51328cdb.png

所以还需要在触发hover时,添加 top:0 ( left就不需要变了,因为原本设置好了 )

2.为什么最后需要设置:active呢?.btn:active{

top: 2px;

}

emmm,就是产生一个点击按钮的动态效果(点击一下,动一下),具体可以查看css :active的作用,这里就不多说了。踩坑

1.button、button::before需要设置z-index,分别为0和-1(确定button在上面一层就行)

不然,会产生如下效果:

a3796c2bbd3576606feb15066a3d5621.png

2.button中记得设置  outline: none;

不然,点击button后,会出现蓝色边框

注:前两次文章中海轰也没有发现这个问题,今天写的的时候,点击后才发现了这个问题

1293fc1dd9ab6e4077b0f6f2e5d24976.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值