웹 프론트엔드 JS 튜토리얼 jQuery+CSS는 측면 슬라이딩 탐색 메뉴를 구현합니다.

jQuery+CSS는 측면 슬라이딩 탐색 메뉴를 구현합니다.

May 16, 2016 am 09:00 AM
css jquery

사이드 메뉴는 웹사이트 디자인에 널리 사용되며, 이런 형태의 메뉴는 많은 웹사이트에서 볼 수 있습니다. 핵심 정보를 표시하여 더 읽기 쉽고 아름답게 만들고 사용자 경험 가치를 만족시킬 수 있습니다!

오늘은 jquery와 css를 활용하여 사이드 슬라이딩 메뉴를 구현하는 방법을 보여드리겠습니다.


효과 표시 소스 코드 다운로드

탐색 메뉴를 생성하려면 먼저 HTML 구조를 살펴보겠습니다.

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Animation Menu Demo</title>
<link rel="stylesheet" href=" 
<link href=&#39;https://fonts.googleapis.com/css?family=Montserrat&#39; rel=&#39;stylesheet&#39; type=&#39;text/css&#39;>
<link rel="stylesheet" href=" 
<script src=" 
</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-인덱스는 :15로 항상 다른 겹치는 요소 위에 위치하도록 합니다. 버튼은 세 개의 수평선으로 구성됩니다. 각 수평선에는 고유한 스타일이 있으며 여기에 .menu-bar 스타일을 추가합니다. 클래스의 나머지 스타일은 별도의 스타일 파일로 이동되었습니다. 애니메이션이 발생하면 .button-open 클래스를 추가합니다. 구현하기가 더 편리할 수 있는 jQuery를 인용합니다.

$(document).ready(function() {
var $toggleButton = $(&#39;.toggle-button&#39;);
$toggleButton.on(&#39;click&#39;, function() {
$(this).toggleClass(&#39;button-open&#39;);
});
});
로그인 후 복사

초보자는 jQuery에 익숙하지 않을 수 있습니다. 무슨 일이 일어나는지 설명하겠습니다. 먼저 버튼이 포함된 $togglebutton이라는 변수를 초기화합니다. 이를 변수로 저장한 다음 버튼 클릭을 수신하는 이벤트 모니터를 만듭니다. 클릭할 때마다 이벤트 리스너는 .button-open을 토글하기 위해 메서드 함수 토글클래스()를 실행합니다.

.button-open 이를 사용하여 이러한 요소가 표시되는 방식을 변경할 수 있습니다. CSS3의translate(),rotate()함수를 사용하여 위쪽과 아래쪽 수평선을 45도 회전시키면 가운데 수평선이 점차 사라집니다. 데모에서 버튼을 클릭하면 효과를 볼 수 있습니다.

사이드 메뉴

사이드 슬라이드 메뉴의 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를 사용하여 다른 클래스를 호출하여 표시하고 닫습니다. JavaScript 코드는 다음과 같습니다.

$(document).ready(function() {
var $toggleButton = $(&#39;.toggle-button&#39;),
$menuWrap = $(&#39;.menu-wrap&#39;);
$toggleButton.on(&#39;click&#39;, function() {
$(this).toggleClass(&#39;button-open&#39;);
$menuWrap.toggleClass(&#39;menu-show&#39;);
});
});
로그인 후 복사

메뉴의 모든 항목이 포함된 $menuwrap 변수를 추가하고 동일한 이벤트를 사용하여 버튼을 생성합니다. 이 .menu-show에는 왼쪽 여백이 0이고 상자 그림자 효과가 추가됩니다.

.menu-show {
margin-left: 0;
box-shadow: 4px 2px 15px 1px #B9ADAD;
}
로그인 후 복사

하위 메뉴 및 링크

목록 항목에 .menu-item-has-children 클래스가 있음을 알 수 있습니다. 하위 메뉴가 포함되어 있습니다. 동시에 링크 뒤에는 .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 의사 요소 패키지가 있습니다. 기본적으로 하위 메뉴는 숨겨져 있으며 상위 메뉴를 클릭할 때만 나타납니다.

$(document).ready(function() {
var $sidebarArrow = $(&#39;.sidebar-menu-arrow&#39;);
$sidebarArrow.click(function() {
$(this).next().slideToggle(300);
});
});
로그인 후 복사

화살표를 클릭하면 대상 범위의 다음 요소 다음에 함수가 호출되어 표시됩니다. 우리는 jquery의 슬라이드토글을 사용합니다. 요소의 슬라이딩 효과를 표시하거나 사라지게 합니다. 이 함수에는 애니메이션 시간 매개변수가 있습니다.

마지막으로 데모 메뉴 항목에 호버 효과가 있습니다. ::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인 각 링크 아래에 절대 위치의 블록 수준 요소가 포함되어 있습니다. 우리는 선에 배경색을 적용하는 것이 아니라 배경 이미지에 선형 그라데이션() 함수를 사용합니다. 이 함수의 목적은 색상 그라데이션을 만드는 것이지만 백분율을 지정하여 그라데이션 색상을 변경할 수도 있습니다.

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

여기 선의 절반은 투명하고 나머지 절반은 노란색입니다. 투명한 부분이 모든 링크의 너비를 차지하도록 배경 크기를 너비의 200%로 전달합니다.

투명한 부분은 다른 색상을 사용해도 됩니다. 이렇게 하면 선이 다른 색상으로 채워진 듯한 착각이 들지만 실제로는 두 가지 색상의 선일 뿐입니다.

위는 사이드 슬라이딩 네비게이션 메뉴 code_jquery를 구현하기 위한 jQuery+CSS의 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!


본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

부트 스트랩에 분할 라인을 작성하는 방법 부트 스트랩에 분할 라인을 작성하는 방법 Apr 07, 2025 pm 03:12 PM

부트 스트랩 분할 라인을 만드는 두 가지 방법이 있습니다 : 태그를 사용하여 수평 분할 라인이 생성됩니다. CSS 테두리 속성을 사용하여 사용자 정의 스타일 분할 라인을 만듭니다.

부트 스트랩에 사진을 삽입하는 방법 부트 스트랩에 사진을 삽입하는 방법 Apr 07, 2025 pm 03:30 PM

Bootstrap에 이미지를 삽입하는 방법에는 여러 가지가 있습니다. HTML IMG 태그를 사용하여 이미지를 직접 삽입하십시오. 부트 스트랩 이미지 구성 요소를 사용하면 반응 형 이미지와 더 많은 스타일을 제공 할 수 있습니다. 이미지 크기를 설정하고 IMG-Fluid 클래스를 사용하여 이미지를 적응할 수 있도록하십시오. IMG 통과 클래스를 사용하여 테두리를 설정하십시오. 둥근 모서리를 설정하고 IMG 라운드 클래스를 사용하십시오. 그림자를 설정하고 그림자 클래스를 사용하십시오. CSS 스타일을 사용하여 이미지를 조정하고 배치하십시오. 배경 이미지를 사용하여 배경 이미지 CSS 속성을 사용하십시오.

부트 스트랩 크기를 조정하는 방법 부트 스트랩 크기를 조정하는 방법 Apr 07, 2025 pm 03:18 PM

부트 스트랩에서 요소의 크기를 조정하려면 다음을 포함하여 차원 클래스를 사용할 수 있습니다.

HTML, CSS 및 JavaScript의 역할 : 핵심 책임 HTML, CSS 및 JavaScript의 역할 : 핵심 책임 Apr 08, 2025 pm 07:05 PM

HTML은 웹 구조를 정의하고 CSS는 스타일과 레이아웃을 담당하며 JavaScript는 동적 상호 작용을 제공합니다. 세 사람은 웹 개발에서 의무를 수행하고 화려한 웹 사이트를 공동으로 구축합니다.

Vue에서 부트 스트랩을 사용하는 방법 Vue에서 부트 스트랩을 사용하는 방법 Apr 07, 2025 pm 11:33 PM

vue.js에서 bootstrap 사용은 5 단계로 나뉩니다 : Bootstrap 설치. main.js.의 부트 스트랩 가져 오기 부트 스트랩 구성 요소를 템플릿에서 직접 사용하십시오. 선택 사항 : 사용자 정의 스타일. 선택 사항 : 플러그인을 사용하십시오.

부트 스트랩을위한 프레임 워크를 설정하는 방법 부트 스트랩을위한 프레임 워크를 설정하는 방법 Apr 07, 2025 pm 03:27 PM

부트 스트랩 프레임 워크를 설정하려면 다음 단계를 따라야합니다. 1. CDN을 통해 부트 스트랩 파일 참조; 2. 자신의 서버에서 파일을 다운로드하여 호스팅하십시오. 3. HTML에 부트 스트랩 파일을 포함; 4. 필요에 따라 Sass/Less를 컴파일하십시오. 5. 사용자 정의 파일을 가져옵니다 (선택 사항). 설정이 완료되면 Bootstrap의 그리드 시스템, 구성 요소 및 스타일을 사용하여 반응 형 웹 사이트 및 응용 프로그램을 만들 수 있습니다.

부트 스트랩 버튼을 사용하는 방법 부트 스트랩 버튼을 사용하는 방법 Apr 07, 2025 pm 03:09 PM

부트 스트랩 버튼을 사용하는 방법? 부트 스트랩 CSS를 소개하여 버튼 요소를 만들고 부트 스트랩 버튼 클래스를 추가하여 버튼 텍스트를 추가하십시오.

부트 스트랩 날짜를 보는 방법 부트 스트랩 날짜를 보는 방법 Apr 07, 2025 pm 03:03 PM

답 : 부트 스트랩의 날짜 선택기 구성 요소를 사용하여 페이지에서 날짜를 볼 수 있습니다. 단계 : 부트 스트랩 프레임 워크를 소개하십시오. HTML에서 날짜 선택기 입력 상자를 만듭니다. 부트 스트랩은 선택기에 스타일을 자동으로 추가합니다. JavaScript를 사용하여 선택한 날짜를 얻으십시오.

See all articles