목차
질문 이해 : 햄버거 메뉴의 로직 표시
기존 코드를 분석합니다
HTML 구조
CSS 스타일
자바 스크립트 코드
문제 분석 및 솔루션
최적화 제안
부트 스트랩이있는 반응 형 탐색 막대를 빠르게 구현하십시오
웹 프론트엔드 HTML 튜토리얼 햄버거 메뉴의 디스플레이 효과 실현에 대한 튜토리얼 클릭

햄버거 메뉴의 디스플레이 효과 실현에 대한 튜토리얼 클릭

Oct 06, 2025 pm 10:00 PM

햄버거 메뉴의 디스플레이 효과 실현에 대한 튜토리얼 클릭

이 기사는 개발자가 햄버거 메뉴를 표시 할 수없는 문제를 해결하는 데 도움이됩니다. HTML 구조, CSS 스타일 및 JavaScript 코드를 분석함으로써, 우리는 햄버거 메뉴의 디스플레이를 올바르게 구현하고 햄버거 메뉴의 기능을 숨기는 방법을 자세히 설명하고 독자가 실제 프로젝트에 신속하게 마스터하고 적용 할 수 있도록 최적화 된 코드 예제를 제공합니다. 동시에 부트 스트랩 프레임 워크를 사용하여 반응 형 내비게이션 바를 신속하게 구축하도록 도입됩니다.

질문 이해 : 햄버거 메뉴의 로직 표시

버거 메뉴는 종종 소형 화면 장치에서 기존 내비게이션 막대를 교체하고 화면 공간을 절약하는 데 사용됩니다. 기본 원칙은 다음과 같습니다.

  1. 내비게이션 막대 숨기기 : 작은 화면 아래에서 탐색 표시 줄은 기본적으로 숨겨져 있습니다.
  2. 햄버거 아이콘 표시 : 햄버거 아이콘 (보통 3 개의 수평선)을 표시하십시오.
  3. 클릭 이벤트 : 사용자가 햄버거 아이콘을 클릭하면 탐색 표시 줄이 표시됩니다.
  4. 다시 클릭하십시오 : 햄버거 아이콘을 다시 클릭하면 탐색 표시 줄을 숨 깁니다.

기존 코드를 분석합니다

제공된 정보에 따르면 HTML 구조에는 네비게이션 바 Navbar와 햄버거 아이콘이 포함 된 이동 영역이 포함 된 헤더 영역이 포함되어 있습니다. CSS 스타일은 작은 화면에서 Navbar를 숨기고 이동 영역에 햄버거 아이콘을 표시하는 데 사용됩니다. JavaScript 코드는 햄버거 아이콘의 클릭 이벤트를 듣고 Navbar의 활성 클래스를 추가하거나 제거하여 디스플레이를 제어하고 탐색 표시 줄의 숨기기에 사용됩니다.

HTML 구조

 
    <a href="#"> <img id="icon-home" src="iconos/menu.jpg" alt=""> </a>
    <div>
        <ul id="navbar">
            <li> <a class="active" href="index.html"> home </a> </li>
            <li> <a href="shop.html"> Shop </a> </li>
            <li> <a href="blog.html"> blog </a> </li>
            <li> <a href="about.html"> 정보 </a> </li>
            <li> <a href="contact.html"> contact </a> </li>
            <li> <a href="cart.html"> <i> <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-bag" viewbox="0 16 16"> V4H-5V-.5A2.5 2.5 0 0 1 8 1ZM3.5 3V-.5A3.5 3.5 0 1 0-7 0V4H1V10A2 2 0 0 0 2 2H10A2 2 0 0 0 2-2V4H-3.5ZM2 5H12V9A1 1 0 1-1 1H3A1 1 0 0 1-1-1v5z "/> </svg> </i> </a> </li>
        </ul>
    </div>
    <div id="mobile">
        <a href="cart.html"> <i> <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-bag" viewbox="0 0 16 16"> V4H-5V-.5A2.5 2.5 0 1 8 1ZM3.5 3V-.5A3.5 3.5 0 1 0-7 0V4H1V10A2 2 0 0 0 2 2H10A2 2 0 0 0 2-2V4H-3.5ZM2 5H12V9A1 1 0 1-1 1H3A1 1 0 1-1-1V5Z "/> </svg> </i>>.
        <i id="bar" class="fas fa-outdent"> </i>
    </a>
</div>
섹션>

CSS 스타일

 #이동하는{
    디스플레이 : 없음;
    정렬 구조 : 센터;
}  
@Media (max-width : 799px) {
    #NAVBAR {
        디스플레이 : Flex;
        플렉스 방향 : 열;
        정렬 구조 : Flex-Start;
        정당화 컨텐츠 : Flex-Start;
        위치 : 고정;
        상단 : 0;
        오른쪽 : -300px;
        높이 : 100VH;
        너비 : 300px;
        배경색 : #fefefe;
        Box-Shadow : 0 40px 60px rgb (0, 0, 0, 0.1);
        패딩 : 80px 0 10;
    }

    #navbar.active {
        오른쪽 : 0px;
    }

    #Navbar li {
        마진 바닥 : 25px;
    }
    #이동하는{
        디스플레이 : Flex;
        정렬 구조 : 센터;
    }    
    #mobile i {
        색상 : #1A1A1A;
        글꼴 크기 : 24px;
        왼쪽 패딩 : 20px;

    }
}

자바 스크립트 코드

 const bar = document.getElementById ( 'bar');
const nav = document.getElementById ( 'navbar');

if (bar) {
    bar.addeventListener ( 'click', () => {
        nav.classlist.add ( 'active');
    })
};

문제 분석 및 솔루션

위 코드의 문제는 다음과 같습니다.

  • 활성 클래스를 제거하기위한 논리 누락 : 햄버거 아이콘을 클릭하면 활성 클래스가 추가되므로 탐색 표시 줄이 나타나지 만 다시 클릭하면 숨길 수 없습니다.

해결책:

활성 클래스를 전환하기 위해 클릭하는 기능을 실현하려면 JavaScript 코드를 수정하십시오.

 const bar = document.getElementById ( 'bar');
const nav = document.getElementById ( 'navbar');

if (bar) {
    bar.addeventListener ( 'click', () => {
        nav.classlist.toggle ( 'Active');
    });
};

ClassList.toggle ( 'Active') 메소드를 사용하여 Navbar 요소의 활성 클래스를 추가하거나 제거하여 디스플레이와 숨겨진 사이의 전환을 달성 할 수 있습니다.

최적화 제안

  1. 더 많은 의미 론적 클래스 이름을 사용하십시오 : 예를 들어, 코드 가독성을 향상시키기 위해 활성 대신 IS- 활성을 사용할 수 있습니다.

  2. 전환 효과 추가 : CSS의 전환 속성을 통해 디스플레이에 전환 효과를 추가하고 탐색 표시 줄을 숨길 수있어 사용자 경험을 향상시킬 수 있습니다.

 #NAVBAR {
       / * ... 기존 스타일 ... */
       전환 : 오른쪽 0.3 초의 편안함; /* 전환 효과 추가*/
   }
  1. 접근성 고려 : 키보드 내비게이션 및 스크린 리더에서 버거 메뉴가 잘 작동하는지 확인하십시오. 예를 들어, 기능을 설명하기 위해 햄버거 아이콘에 aria-label 속성을 추가하십시오.
 <i id="bar" class="fas fa-outdent" aria-label="Toggle Navigation"> </i>

부트 스트랩이있는 반응 형 탐색 막대를 빠르게 구현하십시오

Bootstrap은 반응 형 웹 페이지를 빠르게 구축 할 수있는 풍부한 구성 요소와 스타일을 제공하는 인기있는 프론트 엔드 프레임 워크입니다. 부트 스트랩을 사용하면 햄버거 메뉴의 구현을 단순화 할 수 있습니다.

 


    <meta charset="utf-8">
    <meta name="viewport" content="width = device-width, 초기 스케일 = 1.0">
    <title> Bootstrap Navbar </title>
    <link rel="스타일 시트" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css">



    <nav class="Navbar Navbar-expand-lg navbar-light bg-light">
        <a class="navbar-brand" href="#"> navbar </a>
        <button class="navbar-toggler" type="button" data-toggle="붕괴" data-target="#navbarnav" aria-controls="navbarnav" aria-expanded="false" aria-label="Toggle Navigation">
            <span class="Navbar-Toggler-Icon"> </span>
        버튼>
        <div class="Collapse Navbar-Collapse" id="navbarnav">
            <ul class="Navbar-Nav">
                <li class="nav-item active">
                    <a class="nav-link" href="#"> home <span class="sr-only"> (현재) </span> </a>
                </li>
                <li class="nav-item">
                    <a class="nav-link" href="#"> 특징 </a>
                </li>
                <li class="nav-item">
                    <a class="nav-link" href="#"> 가격 </a>
                </li>
                <li class="nav-item">
                    <a class="nav-link disabled" href="#" tabindex="-1" aria disabled> disabled </a>
                </li>
            </ul>
        </div>
    </button></nav>

    <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js"> </script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js"> </script>
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"> </script>


위 내용은 햄버거 메뉴의 디스플레이 효과 실현에 대한 튜토리얼 클릭의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Stock Market GPT

Stock Market GPT

더 현명한 결정을 위한 AI 기반 투자 연구

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

뜨거운 주제

vue.js 프로젝트는 서버리스 환경에서 로컬로 실행됩니다. 단일 HTML 파일 포장 및 배포에 대한 안내서 vue.js 프로젝트는 서버리스 환경에서 로컬로 실행됩니다. 단일 HTML 파일 포장 및 배포에 대한 안내서 Sep 08, 2025 pm 10:42 PM

이 튜토리얼은 웹 서버 나 오프라인 환경없이 index.html 파일을 직접 열어 Vue.js 프로젝트에 빈 페이지가있는 문제를 해결하는 것을 목표로합니다. 기본 VUE CLI 빌드가 실패한 이유를 파고 모든 VUE 코드와 리소스를 단일 HTML 파일에 패키지하는 솔루션을 제공하여 서버 환경에 의존하지 않고도 프로젝트가 로컬 장치에서 독립적으로 실행될 수 있습니다.

HTML에서 이메일 주소로 하이퍼 링크를 만드는 방법은 무엇입니까? HTML에서 이메일 주소로 하이퍼 링크를 만드는 방법은 무엇입니까? Sep 16, 2025 am 02:24 AM

UseMailto : inhreftocreateemaillinks.startwithbasiclinks, add? subject = 및 & body = forpre-filledcontent, andincludemultipleaddressesorcc =, bcc = foradvancedoptions.

HTML에서 호버에 툴팁을 추가하는 방법은 무엇입니까? HTML에서 호버에 툴팁을 추가하는 방법은 무엇입니까? Sep 18, 2025 am 01:16 AM

USETHETITLEATTRIBITFORSIMPLETOOLTIPSORCSSFORCUSTOM-StyledOnes.1.AddTitle = "Text"TOANYELENMENTFORDEFAULTTOOLTIPS.2. FORSTYLEDTOOLTIPS, WRAPTHEELEMENTINICONTAINER, 사용 .TOOLTIPAND.TOOLTIPAND.TOOLTIPTEXTCLASSSSSSPOTIVICIONITINITINING, PSEUDOINUTE, 및 VSEUDOINGIONC

CSS 팁 : 부모 요소에 영향을주지 않고 정확하게 특정 텍스트 내용을 숨기십시오. CSS 팁 : 부모 요소에 영향을주지 않고 정확하게 특정 텍스트 내용을 숨기십시오. Sep 16, 2025 pm 10:54 PM

이 튜토리얼은 CSS를 사용하여 HTML 페이지의 특정 텍스트 내용을 정확하게 숨기는 방법에 대해 자세히 설명합니다. 대상 텍스트의 랩핑 요소에 독점 CSS 클래스를 추가하고 디스플레이를 사용하여 다음과 같습니다. 속성, 개발자는 페이지 요소의 세련된 제어를 달성하여 필요한 부품 만 숨겨 지도록 페이지 레이아웃 및 사용자 경험을 최적화 할 수 있습니다.

JavaScript를 사용하여 클릭 버튼 팝업 챗봇 창을 구현하기위한 튜토리얼 JavaScript를 사용하여 클릭 버튼 팝업 챗봇 창을 구현하기위한 튜토리얼 Sep 08, 2025 pm 11:36 PM

이 기사는 HTML, CSS 및 JavaScript를 사용하여 버튼을 클릭하여 트리거 된 플로팅 챗봇 창을 만드는 방법에 대해 자세히 설명합니다. 고정 된 위치 및 동적 스타일 스위칭을 통해 페이지의 오른쪽 하단에있는 부동 버튼이 실현됩니다. 클릭하면 채팅 창이 나타나고 닫는 기능이 제공됩니다. 자습서에는 개발자가 유사한 기능을 웹 사이트에 쉽게 통합 할 수 있도록 설계된 완전한 코드 예제 및 구현 단계가 포함되어 있습니다.

HTML에서 텍스트를 랩핑하는 방법은 무엇입니까? HTML에서 텍스트를 랩핑하는 방법은 무엇입니까? Sep 21, 2025 am 04:02 AM

usecssfloatpropertytowraptaroundanimage : floatleftfortextontheright, floatrightfortextontheleft, addmarginforspacing 및 clearfloattopreventlayoutissues.

HTML에서 LANG 속성을 설정하는 방법 HTML에서 LANG 속성을 설정하는 방법 Sep 21, 2025 am 02:34 AM

setthelangattributeinthehtmltagtospecypagelanguage, 예를 들어, forenglish; 2.useocodes "es"forspanishor "fr"forfrench; 3. includeregionalvariantswithcodeslite "en-us"또는 "zh-cn"; 4. ApplylangtespecificelementmelementmelementeMelemente

크로스 도메인 iframes를 포함하는 부모 요소를 가진 마우스 딩 이벤트 캡처 : 원리 및 제한 사항 크로스 도메인 iframes를 포함하는 부모 요소를 가진 마우스 딩 이벤트 캡처 : 원리 및 제한 사항 Sep 20, 2025 pm 11:00 PM

이 기사는 크로스 도메인 iframes를 포함하는 부모 div에서 마우스 딩 이벤트를 포착하는 과제를 탐구합니다. 핵심 문제는 브라우저 보안 정책 (동일한 오리핀 정책)이 크로스 도메인 iframe 컨텐츠에서 직접 DOM 이벤트를 듣지 않는다는 것입니다. iframe 소스 도메인 이름이 제어되고 CORS가 구성되지 않는 한 이러한 유형의 이벤트 캡처를 달성 할 수 없습니다. 이 기사는 이러한 보안 메커니즘을 자세히 설명하고 이벤트 상호 작용에 대한 한계를 설명하고 가능한 대안을 제공합니다.

See all articles