温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

CSS如何实现圆形缩放动画

发布时间:2021-05-28 11:52:38 阅读:332 作者:小新 栏目:web开发
前端开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

这篇文章将为大家详细讲解有关CSS如何实现圆形缩放动画,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

最近在做公司的登录页,UE同学希望第三方登录的图标在hover的时候有一个圆形的缩放效果(原话是波纹效果-_-||),效果参考腾讯新闻和网易新闻的分享按钮。

腾讯新闻的分享按钮hover效果(新闻页面):

CSS如何实现圆形缩放动画

网易新闻的分享按钮hover效果(新闻页面):

CSS如何实现圆形缩放动画

看了一下这两个页面的源码,主要是用了 transform:scale() 和 transition ,自己的最终的实现效果如下:

CSS如何实现圆形缩放动画

实现思路大体是模仿网易新闻的,布局如下:

<a href="" class="third-party third-party-weixin">
     <i></i>
     <span></span>
 </a>

外层的a标签用于整体容器和跳转,内层的i标签使用伪元素::before和::after分别作为背景色和前景色,这两个伪元素均绝对定位,垂直水平居中,::after设置缩放属性 transform:scale(0) ,过渡动画属性 transition: all .3s ,正常情况下::before可见,当hover的时候::after设置缩放属性 transform:scale(1) ,两个相邻绝对定位元素在不设置z-index的情况下,文档流在后的元素在上,并且在有过渡动画属性 transition 的情况下实现了缩放动画效果。

span标签用于展示logo,可以是图片或者web字体,只要透明就可以,这里用了图片。 CSS(此处使用的是sass)如下:

.third-party {
    position: relative;
    // 为了兼容firefox必须要变成block或inline-block
    display: inline-block;
    width48px;
    height48px;
    margin: {
        left6%;
        right6%;
    }
    &:hover {
        i {
            &::after {
                transformscale(1);
            }
        }
    }
    span {
        // position: relative是为了兼容firefox和IE
        position: relative;
        display: block;
        width48px;
        height48px;
        background-size30px;
        background-position: center;
        background-repeat: no-repeat;
    }
    i {
        position: absolute;
        top0;
        left0;
        width48px;
        height48px;
        &::before {
            content'';
            border-radius50%;
            position: absolute;
            top0;
            left0;
            right0;
            bottom0;
        }
        &::after {
            content'';
            transition: all .3s;
            border-radius50%;
            position: absolute;
            top0;
            left0;
            right0;
            bottom0;
            transformscale(0);
        }
    }
    &.third-party-weixin {
        span {
            background-imageurl(../images/login/weixin-64.png);
        }
        i {
            &::before {
                background-color#20a839;
            }
            &::after {
                background-color#30cc54;
            }
        }
    }
}

这样这个简单的圆形缩放动画就完成啦。

关于“CSS如何实现圆形缩放动画”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

原文链接:https://www.jb51.net/css/598193.html

css
AI

开发者交流群×