この記事では、HTML5 ブラインドエフェクトのサンプルコードを紹介し、皆さんに共有します。詳細は次のとおりです。
実装方法の紹介:
1. コンテンツレイアウト上にブラインドレイアウトを位置決めして重ね(位置:絶対)、背景を透明(背景色:透明)に設定します。
2. キーフレームは、フェードインとフェードアウト (透明度の変更) およびブラインド ウィンドウ効果アニメーションを定義します。
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: 1; } } @keyframes fadeInOut { 0% { 不透明度: 1; } 50% { 不透明度: 0 } 100% { 不透明度: 1; } } アニメーション: fadeInOut 1s easy-in; -webkit-animation: fadeInOut 1s easy-in; 幅: 100%; 位置: 左: 0; : 1.2rem; li{ 高さ: 0.42rem; オーバーフロー: 背景色:透明; .ye{ -webkit-animation: スライドアウト 1 秒イーズインアウト; 背景色: rgba(0,0,0,.2); : 相対; 上: 50%; } } @-webkit-keyframes slideOut { 0% { パディング-下: 0; } 100% {パディングボトム: 40px; } } @keyframes slideOut { 0% { パディングボトム: 0; } } }
JSコード:
//レイアウトを切り替える $scope.switchLayout = function(){ ... $scope.startBaiYeWindow() //0.5秒間アニメーションを開始した後、レイアウトを表示/非表示に制御 $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 () { アニメーター.クラス名 = 'baiyeWindow'; animatorFadeInOut.className = 'コンテンツフェードアニメーション' }, 0);
以上がこの記事の全内容です。皆様の学習のお役に立てれば幸いです。また、VeVb Wulin Network をご支援いただければ幸いです。