前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >纯CSS3实现悬停时出现对角线耀光效果的按钮

纯CSS3实现悬停时出现对角线耀光效果的按钮

作者头像
itclanCoder
发布2023-09-14 17:17:39
1530
发布2023-09-14 17:17:39
举报
文章被收录于专栏:itclanCoderitclanCoder

示例代码

代码语言:javascript
复制
<template>
   <div class="example-xuantingduijiao">
        <div class="btn-wrapper"><a class="btn">悬停对角线耀光</a></div>
   </div>

</template>
<style>
.example-xuantingduijiao {
    background: #BFFFBC;
}
.btn-wrapper {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    margin: -28px 0 0 -74.5px;
    box-shadow: 0 0 10px -10px black;
}
.btn {
    display: block;
    background: #A09EBB;
    padding: 20px 40px;
    position: relative;
    z-index: 0;
    overflow: hidden;
    cursor: pointer;
    border-radius: 2px;
    color: #FFF;
    border-bottom: 3px solid #6c3b96;
    font-weight: bold;
    font-family: sans-serif;
    letter-spacing: 1px;
}
.btn:after {
    content: "";
    display: block;
    position: absolute;
    z-index: 1;
    background: white;
    width: 150%;
    height: 100%;
    bottom: -80px;
    right: 40px;
    transform: rotate(30deg);
}
.btn-wrapper:hover {
    box-shadow: 0 10px 20px -10px black;
}
.btn-wrapper:hover a {
    animation: grow 600ms ease-in-out forwards;
}
.btn-wrapper:hover a:after {
    animation: shine 2s ease-in-out forwards;
    animation-iteration-count: infinite;
}
@keyframes shine {
    from {
        transform: translateX(0px) translateY(0px) rotate(30deg);
        opacity: 0.1;
    }
    to {
        transform: translateX(200px) translateY(-300px) rotate(30deg);
        opacity: 1;
    }
}
@keyframes grow {
    from {
        transform: scale(1);
    }
    to {
        transform: scale(1.1);
    }
}
</style>

实现这个效果,主要是结合css3中的transform,以及动画关键帧@keyframes实现

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2023-08-09 10:11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 itclanCoder 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档