美文网首页
一个简单的CSS圆形缩放动画

一个简单的CSS圆形缩放动画

作者: Ruby君 | 来源:发表于2018-01-29 18:24 被阅读65次

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

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

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

自己的实现效果

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

<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;
    width: 48px;
    height: 48px;
    margin: {
        left: 6%;
        right: 6%;
    }
    &:hover {
        i {
            &::after {
                transform: scale(1);
            }
        }
    }
    span {
        // position: relative是为了兼容firefox和IE
        position: relative;
        display: block;
        width: 48px;
        height: 48px;
        background-size: 30px;
        background-position: center;
        background-repeat: no-repeat;
    }
    i {
        position: absolute;
        top: 0;
        left: 0;
        width: 48px;
        height: 48px;
        &::before {
            content: '';
            border-radius: 50%;
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
        }
        &::after {
            content: '';
            transition: all .3s;
            border-radius: 50%;
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            transform: scale(0);
        }
    }
    &.third-party-weixin {
        span {
            background-image: url(../images/login/weixin-64.png);
        }
        i {
            &::before {
                background-color: #20a839;
            }
            &::after {
                background-color: #30cc54;
            }
        }
    }
}

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

PS: ScreenToGif录GIF真好用,推荐一下。

相关文章

  • 一个简单的CSS圆形缩放动画

    最近在做公司的登录页,UE同学希望第三方登录的图标在hover的时候有一个圆形的缩放效果(原话是波纹效果-_-||...

  • 第一篇

    使用css实现旋转,缩放,阴影,动画的效果。

  • 动画

    CABasicAnimation基础核心动画 缩放动画 图片抖动 根据圆形的路径做移动的效果. 转场动画 创建转场...

  • transfrom&transition&ani

    transform transform是才css3动画的主要部分,可以实现旋转、缩放、倾斜、移动等动画,主要用到的...

  • Android5.0使用共享元素实现转场动画

    1.整体效果首先看下android5.0以上的转场动画用共享元素实现以及配合补间动画和圆形缩放动画实现的activ...

  • Property Animation属性动画

    动画类型 View Animation(Tween Animation 补间动画)只能支持简单的缩放、平移、旋转、...

  • iOS动画学习之缩放控件

    实现控件的缩放很简单,就是用动画改变frame的大小。 和操作layer的动画不同,控件缩放其实是调用UIView...

  • UIView和CAKeyframeAnimation缩放动画

    UIView的缩放动画 CAKeyframeAnimation的缩放动画

  • 页面滚动动画-wow.js及Animate.css

    Animate.css 官网 简介Animate.css是一个纯CSS动画库,官方给出了70多种动画特效,使用简单...

  • Android官方圆形揭露动画

    圆形揭露动画 今天看官方的动画效果无意发现了这个动画,可能是之前没怎么关注吧使用也很简单,其实就是一个圆形缩小或者...

网友评论

      本文标题:一个简单的CSS圆形缩放动画

      本文链接:https://www.haomeiwen.com/subject/yylfzxtx.html