溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

css3中怎么實(shí)現(xiàn)一個(gè)垂直下拉動(dòng)畫菜單

發(fā)布時(shí)間:2021-06-25 15:48:35 來(lái)源:億速云 閱讀:133 作者:Leah 欄目:web開發(fā)

css3中怎么實(shí)現(xiàn)一個(gè)垂直下拉動(dòng)畫菜單,相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。



<nav>
       <ul class="mcd-menu">
           <li>
               <a href="">
                   <i class="fa fa-home"></i>
                   <strong>Home</strong>
                   <small>sweet home</small>
               </a>
           </li>
           <li>
               <a href="" class="active">
                   <i class="fa fa-edit"></i>
                   <strong>About us</strong>
                   <small>sweet home</small>
               </a>
           </li>
           <li>
               <a href="">
                   <i class="fa fa-gift"></i>
                   <strong>Features</strong>
                   <small>sweet home</small>
               </a>
           </li>
           <li>
               <a href="">
                   <i class="fa fa-globe"></i>
                   <strong>News</strong>
                   <small>sweet home</small>
               </a>
           </li>
           <li>
               <a href="">
                   <i class="fa fa-comments-o"></i>
                   <strong>Blog</strong>
                   <small>what they say</small>
               </a>
               <ul>
                   <li><a href="#"><i class="fa fa-globe"></i>Mission</a></li>
                   <li>
                       <a href="#"><i class="fa fa-group"></i>Our Team</a>
                       <ul>
                           <li><a href="#"><i class="fa fa-female"></i>Leyla Sparks</a></li>
                           <li>
                               <a href="#"><i class="fa fa-male"></i>Gleb Ismailov</a>
                               <ul>
                                   <li><a href="#"><i class="fa fa-leaf"></i>About</a></li>
                                   <li><a href="#"><i class="fa fa-tasks"></i>Skills</a></li>
                               </ul>
                           </li>
                           <li><a href="#"><i class="fa fa-female"></i>Viktoria Gibbers</a></li>
                       </ul>
                   </li>
                   <li><a href="#"><i class="fa fa-trophy"></i>Rewards</a></li>
                   <li><a href="#"><i class="fa fa-certificate"></i>Certificates</a></li>
               </ul>
           </li>
           <li>
               <a href="">
                   <i class="fa fa-picture-o"></i>
                   <strong>Portfolio</strong>
                   <small>sweet home</small>
               </a>
           </li>
           <li>
               <a href="">
                   <i class="fa fa-envelope-o"></i>
                   <strong>Contacts</strong>
                   <small>drop a line</small>
               </a>
           </li>
           <li class="float">
               <a class="search">
                   <input type="text" value="search ...">
                   <button><i class="fa fa-search"></i></button>
               </a>
               <a href="" class="search-mobile">
                   <i class="fa fa-search"></i>
               </a>
           </li>
       </ul>
   </nav>

這里用ul構(gòu)造了菜單的基本結(jié)構(gòu)。

接下來(lái)就利用CSS3代碼來(lái)實(shí)現(xiàn)菜單的下拉和動(dòng)畫效果。

CSS代碼比較繁瑣,這里我只是提供一些核心的CSS代碼,完整的代碼大家可以在文章最后下載學(xué)習(xí)。

這是鼠標(biāo)滑過(guò)菜單項(xiàng)時(shí)的動(dòng)畫代碼:

代碼如下:


.mcd-menu li a i, .mcd-menu li a strong, .mcd-menu li a small {
 position: relative;
 
 transition: all 300ms linear;
 -o-transition: all 300ms linear;
 -ms-transition: all 300ms linear;
 -moz-transition: all 300ms linear;
 -webkit-transition: all 300ms linear;
}
.mcd-menu li:hover > a i {
   opacity: 1;
   -webkit-animation: moveFromTop 300ms ease-in-out;
   -moz-animation: moveFromTop 300ms ease-in-out;
   -ms-animation: moveFromTop 300ms ease-in-out;
   -o-animation: moveFromTop 300ms ease-in-out;
   animation: moveFromTop 300ms ease-in-out;
}
.mcd-menu li:hover a strong {
   opacity: 1;
   -webkit-animation: moveFromLeft 300ms ease-in-out;
   -moz-animation: moveFromLeft 300ms ease-in-out;
   -ms-animation: moveFromLeft 300ms ease-in-out;
   -o-animation: moveFromLeft 300ms ease-in-out;
   animation: moveFromLeft 300ms ease-in-out;
}
.mcd-menu li:hover a small {
   opacity: 1;
   -webkit-animation: moveFromRight 300ms ease-in-out;
   -moz-animation: moveFromRight 300ms ease-in-out;
   -ms-animation: moveFromRight 300ms ease-in-out;
   -o-animation: moveFromRight 300ms ease-in-out;
   animation: moveFromRight 300ms ease-in-out;
}</p> <p>.mcd-menu li:hover > a {
 color: #e67e22;
}

以下定義了鼠標(biāo)滑過(guò)后文字圖標(biāo)滑過(guò)的動(dòng)畫,分別是從頂部劃入,從左側(cè)劃入,從右側(cè)劃入:

代碼如下:


@-webkit-keyframes moveFromTop {
   from {
       opacity: 0;
       -webkit-transform: translateY(200%);
       -moz-transform: translateY(200%);
       -ms-transform: translateY(200%);
       -o-transform: translateY(200%);
       transform: translateY(200%);
   }
   to {
       opacity: 1;
       -webkit-transform: translateY(0%);
       -moz-transform: translateY(0%);
       -ms-transform: translateY(0%);
       -o-transform: translateY(0%);
       transform: translateY(0%);
   }
}
@-webkit-keyframes moveFromLeft {
   from {
       opacity: 0;
       -webkit-transform: translateX(200%);
       -moz-transform: translateX(200%);
       -ms-transform: translateX(200%);
       -o-transform: translateX(200%);
       transform: translateX(200%);
   }
   to {
       opacity: 1;
       -webkit-transform: translateX(0%);
       -moz-transform: translateX(0%);
       -ms-transform: translateX(0%);
       -o-transform: translateX(0%);
       transform: translateX(0%);
   }
}
@-webkit-keyframes moveFromRight {
   from {
       opacity: 0;
       -webkit-transform: translateX(-200%);
       -moz-transform: translateX(-200%);
       -ms-transform: translateX(-200%);
       -o-transform: translateX(-200%);
       transform: translateX(-200%);
   }
   to {
       opacity: 1;
       -webkit-transform: translateX(0%);
       -moz-transform: translateX(0%);
       -ms-transform: translateX(0%);
       -o-transform: translateX(0%);
       transform: translateX(0%);
   }
}

看完上述內(nèi)容,你們掌握css3中怎么實(shí)現(xiàn)一個(gè)垂直下拉動(dòng)畫菜單的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI