国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jQuery+CSS實現一個側滑導航菜單代碼

2019-11-20 10:07:42
字體:
來源:轉載
供稿:網友

側滑菜單在網站設計中應用比較廣泛,在許多網站上都可以看到此種類型的菜單。它可以展示重點信息,使其更有可讀性和美觀性,滿足用戶體驗價值!

今天小編給大家展示如何使用jquery和css實現側滑菜單。


效果展示      源碼下載

為了建立導航菜單,讓我們先看看html結構:

<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>Animation Menu Demo</title><link rel="stylesheet" ><link  rel='stylesheet' type='text/css'><link rel="stylesheet" ><script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.0.0-beta1/jquery.js"></script><script src="script.js"></script><link rel="stylesheet" href="style.css"></head><body><!-- Content goes here --></body></html> 

首先,我們引用normalize.css作為默認樣式,以確保我們的菜單在每個瀏覽器是一樣的。我們使用字體圖標fontawesome來顯示菜單項向下的圖標。我們還需要引用jQuery來實現菜單的切換。

面板按鈕

每個網站面板導航按鈕都類似。它往往是一個圖標字體,如fontawesome,但在本教程中我想添加一些動畫,所以我們用橫線來實現?;旧?,我們的按鈕是一個跨度,包含三個div顯示為水平橫線。

<span class="toggle-button"><div class="menu-bar menu-bar-top"></div><div class="menu-bar menu-bar-middle"></div><div class="menu-bar menu-bar-bottom"></div></span> 

樣式看起來如下:

.toggle-button {position: fixed;width: 44px;height: 40px;padding: 4px;transition: .25s;z-index: 15;}.toggle-button:hover {cursor: pointer;}.toggle-button .menu-bar {position: absolute;border-radius: 2px;width: 80%;transition: .5s;}.toggle-button .menu-bar-top {border: 4px solid #555;border-bottom: none;top: 0;}.toggle-button .menu-bar-middle {height: 4px;background-color: #555;margin-top: 7px;margin-bottom: 7px;top: 4px;}.toggle-button .menu-bar-bottom {border: 4px solid #555;border-top: none;top: 22px;}.button-open .menu-bar-top {transform: rotate(45deg) translate(8px, 8px);transition: .5s;}.button-open .menu-bar-middle {transform: translate(230px);transition: .1s ease-in;opacity: 0;}.button-open .menu-bar-bottom {transform: rotate(-45deg) translate(8px, -7px);transition: .5s;} 

按鈕有一個固定的位置,不動時滾動頁面。它也有一個 z-index :15的樣式,以保證它總是保持在其他重疊元素之上。按鈕由三條橫線。每橫線都有自已的樣式,我們給它加上.menu-bar樣式。類其余的樣式被移動到單獨的樣式文件中。動畫發生時,我們添加一個類.button-open。我們引用jQuery,可以比較方便的實現它:

$(document).ready(function() {var $toggleButton = $('.toggle-button');$toggleButton.on('click', function() {$(this).toggleClass('button-open');});}); 

初學者可能不熟悉jQuery,讓我解釋一下這是怎么回事。首先,我們初始化一個變量稱為$togglebutton,其中包含我們的按鈕。我們將它存儲為一個變量,然后我們創建一個事件監視器監聽點擊按鈕。每單擊一次,事件監聽器會執行方法 function toggleclass()來切換.button-open。

.button-open我們可以用它來改變這些元素的顯示方式。我們使用CSS3 translate()和rotate()功能使頂部和底部的橫線旋轉45度,與中間的橫線逐漸消失。你可以點擊Demo中的按鈕來看看效果。

側滑菜單

側滑菜單的html的結構如下:

<div class="menu-wrap"><div class="menu-sidebar"><ul class="menu"><li><a href="#">Home</a></li><li><a href="#">About</a></li><li><a href="#">Blog</a></li><li class="menu-item-has-children"><a href="#">Click The Arrow</a><span class="sidebar-menu-arrow"></span><ul class="sub-menu"><li><a href="#">Alignment</a></li><li><a href="#">Markup</a></li><li><a href="#">Comments</a></li></ul></li><li><a href="#">Courses</a></li><li><a href="#">Get In Touch</a></li></ul> </div></div> 

在這里不詳細解釋每個風格的菜單,我們看下.menu-wrap 的div。它的樣式如下:  

.menu-wrap {background-color: #6968AB;position: fixed;top: 0;height: 100%;width: 280px;margin-left: -280px;font-size: 1em;font-weight: 700;overflow: auto;transition: .25s;z-index: 10;}

它的位置是固定的,所以菜單一直在同一個地方滾動。高度設為100%。注意,左邊距設置為負數,使這菜單從視圖中消失。為了讓它有一個出現的特效,我們用jquery來了調用另一class來顯示和關閉。JavaScript代碼如下:

$(document).ready(function() {var $toggleButton = $('.toggle-button'),$menuWrap = $('.menu-wrap');$toggleButton.on('click', function() {$(this).toggleClass('button-open');$menuWrap.toggleClass('menu-show');});}); 

我們增加一個變量$menuwrap其中包含菜單的所有項,并使用相同的事件來創建按鈕。這個.menu-show的左邊距為0,并增加了一些盒子陰影效果。

.menu-show {margin-left: 0;box-shadow: 4px 2px 15px 1px #B9ADAD;}

子菜單和鏈接

你可能會注意到一個列表項的class .menu-item-has-children。包含子菜單。同時,鏈接后,有一個class .sidebar-menu-arrow。

<li class="menu-item-has-children"><a href="#">Click The Arrow</a><span class="sidebar-menu-arrow"></span><ul class="sub-menu"><!-- List items --></ul></li> 

span 有一個::after偽元素包實現fontawesome箭頭。默認情況下,子菜單是隱藏的,只有單擊父級菜單時才出現:

$(document).ready(function() {var $sidebarArrow = $('.sidebar-menu-arrow');$sidebarArrow.click(function() {$(this).next().slideToggle(300);});}); 

當我們單擊箭頭,一個函數被調用時,它的目標的下一個元素之后的span并使其可見。我們使用的jquery的slidetoggle。它使一個元素滑動效果的出現或消失,函數有一個動畫時間參數。

最后,我們的演示菜單項有一個懸停效果。它是使用一個::after偽元素。代碼如下:

.menu-sidebar li > a::after {content: "";display: block;height: 0.15em;position: absolute;top: 100%;width: 102%;left: 50%;transform: translate(-50%);background-image: linear-gradient(to right, transparent 50.3%, #FFFA3B 50.3%);transition: background-position .2s .1s ease-out;background-size: 200% auto;}.menu-sidebar li > a:hover::after {background-position: -100% 0;} 

這個::after偽元素包含在每個環節下絕對定位的塊級元素,隨著0.15em高度和寬度。我們不只是應用背景顏色的線,我們使用linear-gradient() 在背景圖像功能。雖然這個功能的目的是使顏色梯度,我們可以通過指定的百分比,做了一個漸變的顏色變化。

.menu-sidebar li > a::after {background-image: linear-gradient(to right, transparent 50.3%, #FFFA3B 50.3%);} 

這里一半的線是透明的,另一半是黃色的。通過背景大小200%的寬度,使透明部分占用的所有鏈接的寬度。

而透明的部分可以用其他顏色。這將創建一個線的另一個顏色填充的錯覺,但實際上它只是一二色線。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 安阳市| 东阳市| 惠水县| 雅安市| 平潭县| 泌阳县| 桃江县| 琼中| 象山县| 揭西县| 宁陕县| 兴和县| 秦皇岛市| 塔城市| 太和县| 郓城县| 旌德县| 建宁县| 临泽县| 香港 | 师宗县| 日土县| 双柏县| 宣城市| 湾仔区| 永川市| 怀仁县| 长丰县| 子长县| 阆中市| 昌图县| 江西省| 仙居县| 莆田市| 长岭县| 沙雅县| 吉安县| 个旧市| 巫山县| 福泉市| 得荣县|