今回紹介するのは、パーソナライズされたナビゲーション バーの特殊効果を実装するための JavaScript です。この記事では、全能の JS でさまざまな特殊効果を実現できることがわかっています。
実装の原理:
宙返り雲効果とは:
•この効果は非常に単純です。つまり、マウスが他のナビゲーション ディレクトリに移動すると、背景画像がマウスとともに現在のディレクトリまでスライドします。
実装アイデア:
•マウスが通過するときに、offsetLeftを使用して現在のボックスから左までの距離を取得し、この値をイージングアニメーションの終了値に割り当てます。
•クリックすると、現在の offsetLeft 値を記憶し、マウスが通過するときに、前にクリックした offsetLeft にその値を与えます。
実装コード:
以下は実装コードと詳細なコメントです。中心となるのは、絶対位置を持つスパンタグを設定することで、カプセル化されたアニメーションアニメーションを使用してスパンの「宙返り雲」効果を実現します。 。
<!DOCTYPE html> <html> <head> <title>导航栏筋斗云效果</title> <meta charset="utf-8"> <style type="text/css"> *{ padding: 0; margin: 0; } body{ background-color: rgba(0, 0, 0, 0.6); } .box{ width: 415px; height: 42px; margin: 200px auto; background-color: #fff; position: relative; } ul{ list-style: none; position: relative; } li{ float: left; width: 83px; height: 42px; text-align: center; font: 500 15px/42px "微软雅黑"; cursor: pointer; } span{ position: absolute; left: 0; top: 0; width: 83px; height: 42px; background-image: linear-gradient(to right,#03c03c 50% ,#51ee5d 100%); } </style> </head> <body> <p class="box"> <span></span> <ul> <li>菜单栏1</li> <li>菜单栏2</li> <li>菜单栏3</li> <li>菜单栏4</li> <li>菜单栏5</li> </ul> </p> <script type="text/javascript"> window.onload = function(){ // 鼠标放在哪个li上面,span对应一道到哪里,移开后回到原位置 var liArr = document.getElementsByTagName("li"); var liWidth = liArr[0].offsetWidth; var span = document.getElementsByTagName("span")[0]; // 计数器 var cnt = 0; // for循环绑定事件 for(var i=0; i<liArr.length; i++){ // 自定义属性,然后绑定index属性为索引值 liArr[i].index = i; // 鼠标进入事件 liArr[i].onmouseover = function(){ // 然span运动到该li的索引值位置 animate(span, this.index*liWidth); } // 鼠标移开 liArr[i].onmouseout = function(){ // span运动到原位置 animate(span, cnt*liWidth); } // 点击事件 liArr[i].onclick = function(){ // 计数器记录当前标签索引值 cnt = this.index; animate(span, cnt*liWidth); } } // 缓动动画封装 function animate(element, target){ // 清除间歇调用 clearInterval(element.timer); // 设置超时调用 element.timer = setInterval(function(){ // 设置步数 var step = (target - element.offsetLeft)/10; // 调整步数 step = step > 0 ? Math.ceil(step) : Math.floor(step); // 设置样式 element.style.left = element.offsetLeft + step + "px"; // console.log(1); if(Math.abs(target - element.offsetLeft) < Math.abs(step)){ element.style.left = target + "px"; clearInterval(element.timer); } }, 20); } } </script> </body> </html>
上記の紹介を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。
関連書籍:
以上がJavaScript はパーソナライズされたナビゲーション バー効果を実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。