美文网首页网页前端后台技巧(CSS+HTML)让前端飞互联网科技
前端开发入门到实战:动画优雅降级的简单总结

前端开发入门到实战:动画优雅降级的简单总结

作者: 560b7bb7b879 | 来源:发表于2019-08-15 14:38 被阅读7次

    CSS动画优雅降级的简单总结

    CSS动画相关属性

    transition:兼容性


    transform 3D:兼容性


    transform 2D:兼容性


    animation:


    image

    可以看到动画在IE8(这里主要讨论IE)及以下完全不支持,IE9由于只支持transform(非transform3d)

    优雅降级

    <div class="a"></div>
    

    CSS:

    web前端开发学习Q-q-u-n: 731771211,分享学习的方法和需要注意的小细节,不停更新最新的教程和学习方法(详细的前端项目实战教学视频)
    <style>
    div {
      width: 100px;
      height: 100px;
      background: #3ea5ff;
    }
    .a { /*a初始化元素动画前样式及加入动画*/
      transform: translate3d(-300px,0,0);/*现代浏览器下移开元素*/
      -ms-transform: translate3d(-300px,0,0);/*IE10+下移开元素*/
      opacity: 0;/*透明元素*/
      opacity:1\9\0; /*IE9hack,是元素不透明*/
      animation: leftIn .7s ease-out forwards;  
    
    }
    @keyframes leftIn {
      0% {transform: translate3d(-300px,0,0);opacity: 0}
      100% {transform: translate3d(0,0,0);opacity: 1}
    }
    </style>
    

    主要功臣自然是translate3d,因为IE9不支持自然会忽略掉,所以translate也在IE下不起效了,opacity等简单属性做个hack即可。

    用JQ动画来替代,还是上面那个例子吧:
    首先当然要判断浏览器支不支持要用到的CSS属性,判断函数如下:

    function isSupportThis(attrName) {
        var prefixs = ['webkit', 'Moz', 'ms', 'o'],
            i,
            humpString = [],
            htmlStyle = document.documentElement.style,
            // 将animation-delay这种带杠转化为htmlStyle中的驼峰属性名
            toHumb = function (string) {
                 return string.replace(/-(\w)/g, function ($0, $1) {
                    return $1.toUpperCase();
                });
            };
    
        for (i in prefixs) {
            humpString.push(toHumb(prefixs[i] + '-' + attrName))
        };
    
        humpString.push(toHumb(attrName));
    
        for (i in humpString) {
            if (humpString[i] in htmlStyle) return true
        };
    
        return false
    }
    isSupportThis('animation') // IE9下false
    

    如果不支持的话就对$('.a')做下动画处理,当然,如果动画元素很多且很杂,我们可以事先未那些要进行动画的元素统一加上之类的后面好处理,animation-delay之类的也可以用delay()代替

    自己是一个五年的前端工程师,希望本文对你有帮助!

    这里推荐一下我的前端学习交流扣qun:731771211 ,里面都是学习前端的,如果你想制作酷炫的网页,想学习编程。自己整理了一份2019最全面前端学习资料,从最基础的HTML+CSS+JS【炫酷特效,游戏,插件封装,设计模式】到移动端HTML5的项目实战的学习资料都有整理,送给每一位前端小伙伴,每天分享技术

    点击:加入

    相关文章

      网友评论

        本文标题:前端开发入门到实战:动画优雅降级的简单总结

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