为了账号安全,请及时绑定邮箱和手机立即绑定

Html5百叶窗效果

实现方法介绍:

1,百叶窗布局 用定位(position: absolute)覆盖在content布局之上,背景设置为透明(background-color: transparent)
2,keyframes定义淡入淡出(透明度改变)和百叶窗口效果动画。
3,启动动画是通过设置DOM的className属性的方法,animator.className = 'baiyeWindow'; 监听动画完成事件'animationend',要清除className属性。
4,在内容布局切换的事件,调用启动动画方法,两个布局都需要绑定切换事件 ng-click="switchLayout()"
5,动画执行时序图:


webp

animation time.png

html代码:

<!--要显示百叶窗效果的布局--切换内容--><div id="fadeInOut" class="content"  ng-click="switchLayout()">...</div><!--百叶窗布局-->
 <ul id="baiyeWindow"  ng-click="switchLayout()">
       <li><div class="ye"></div></li>
        <li><div class="ye"></div></li>
        <li><div class="ye"></div></li>
        <li><div class="ye"></div></li>
  </ul>

css样式代码:

  //谈入谈出效果
 .fade-animation{
        @-webkit-keyframes fadeInOut {          0% {
            opacity: 1;
          }          50% {
            opacity: 0;
          }          100% {
            opacity: 1;
          }
        }
    @keyframes fadeInOut {          0% {
            opacity: 1;
          }          50% {
            opacity: 0;
          }          100% {
            opacity: 1;
          }
        }
        animation: fadeInOut 1s ease-in;
        -webkit-animation: fadeInOut 1s ease-in;
      }      //百叶窗效果
      .baiyeWindow{
        width: 100%;
        height: 1.68rem;
        position: absolute;
        left: 0;
        top: 1.2rem;
        li{
          height: 0.42rem;
          line-height: 40px;
          overflow: hidden;
          background-color: transparent;
          .ye{
            -webkit-animation: slideOut 1s ease-in-out;
            animation: slideOut 1s ease-in-out;
            width: 100%;
            background-color: rgba(0,0,0,.2);
            position: relative;
            top: 50%;
          }
        }
        @-webkit-keyframes slideOut {          0% {
            padding-bottom: 0;
            top: 50%;
          }          100% {
            padding-bottom: 40px;
            top: 0;
          }
        }
        @keyframes slideOut {          0% {
            padding-bottom: 0;
            top: 50%;
          }          100% {
            padding-bottom: 40px;
            top: 0;
          }
        }
      }

JS代码:

//切换布局$scope.switchLayout = function(){
    ...
    $scope.startBaiYeWindow();    //启动动画0.5s后,控制布局显示/隐藏
    $timeout(function () {             if ($scope.show) {
                  $scope.show = false;
              } else {
                    ....
              }
     }, 500);
 }//启动动画
        $scope.startBaiYeWindow = function () {            var animator = document.getElementById('baiyeWindow');            var animatorFadeInOut = document.getElementById('fadeInOut');
            animator.addEventListener('animationend', function () {
                animator.className = '';
                animatorFadeInOut.className = 'content';
            });
            $timeout(function () {
                animator.className = 'baiyeWindow';
                animatorFadeInOut.className = 'content fade-animation';
            }, 0);
        };



作者:竿牍
链接:https://www.jianshu.com/p/155a05fa5723


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消