本文介绍了Html5百叶窗效果的示例代码,分享给大家,具体如下:
实现方法介绍:
1,百叶窗布局 用定位(position: absolute)覆盖在content布局之上,背景设置为透明(background-color: transparent)
2,keyframes定义淡入淡出(透明度改变)和百叶窗口效果动画。
3,启动动画是通过设置DOM的className属性的方法,animator.className = 'baiyeWindow'; 监听动画完成事件'animationend',要清除className属性。
4,在内容布局切换的事件,调用启动动画方法,两个布局都需要绑定切换事件 ng-click="switchLayout()"
5,动画执行时序图:
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); };
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
微信搜索【 脑子进煎鱼了 】关注这一只爆肝煎鱼。本文 GitHub github.com/eddycj...
前言 演示下太老版本浏览器的渐变实现了[IE9-]; IE9以前,渐变都是通过滤镜实现的...
第一种: 用css的position属性 style type=text/css .div1 { width: 100px; heig...
1.文章标题列表中日期居右显示的方法: 复制代码 代码如下: pspan2010-10-10/span...
不知道从什么时候开始,在网络上到处可以看到div+css,到底什么是div+css呢?难...
前言 在浅析函数式编程之前,我们需要明确两个前导概念,即:编程范式(Programm...
先自上而下,后自底向上的介绍 ElasticSearch 的底层工作原理,试图回答以下问题...
背景 在不知不觉中,忙碌的一年将要结束,又到了一年一度的活动期了,为了展现喜...
简介: 【开通指南】实时计算 Flink 全托管版本 1、试用的实时计算 Flink 版产品...
坐标成都,大专,4年前端,分享一次自己在蚂蚁金服的面试经历。 一面 1.自我介绍...