웹 프론트엔드 CSS 튜토리얼 순수한 CSS 드롭다운 메뉴를 만드는 방법은 무엇입니까?

순수한 CSS 드롭다운 메뉴를 만드는 방법은 무엇입니까?

Dec 10, 2024 am 06:44 AM

How to Craft a Pure CSS Dropdown Menu?

순수한 CSS 드롭다운 메뉴 만들기

웹 디자인 영역에서 원활하고 사용자 친화적인 탐색 메뉴를 만드는 능력은 최고의. 다양한 메뉴 스타일 중에서 드롭다운 메뉴는 탐색 옵션을 우아하게 구성하고 표시하는 기능이 두드러집니다. 이 기사에서는 기능적일 뿐만 아니라 시각적으로도 시선을 사로잡는 순수한 CSS 드롭다운 메뉴를 만드는 복잡한 기술을 탐구할 것입니다.

HTML 구조

기본 드롭다운 메뉴는 비교적 간단합니다. 메뉴 항목의 컨테이너 역할을 하는 순서가 지정되지 않은 목록(<ul>)으로 시작합니다. 목록 내에서 각 메뉴 항목은 목록 항목(

  • )으로 표시됩니다.

    예제 HTML:

    <ul>
    로그인 후 복사

    CSS 스타일링

    HTML 구조를 기능적 드롭다운 메뉴로 변환하기 위해 다음 CSS를 사용합니다. 스타일:

    ul {
      font-family: Arial, Verdana;
      font-size: 14px;
      margin: 0;
      padding: 0;
      list-style: none;
    }
    
    ul li {
      display: block;
      position: relative;
      float: left;
    }
    
    li ul {
      display: none;
    }
    
    ul li a {
      display: block;
      text-decoration: none;
      color: #ffffff;
      border-top: 1px solid #ffffff;
      padding: 5px 15px 5px 15px;
      background: #2C5463;
      margin-left: 1px;
      white-space: nowrap;
    }
    
    ul li a:hover {
      background: #617F8A;
    }
    
    li:hover ul {
      display: block;
      position: absolute;
    }
    
    li:hover li {
      float: none;
      font-size: 11px;
    }
    
    li:hover a {
      background: #617F8A;
    }
    
    li:hover li a:hover {
      background: #95A9B1;
    }
    로그인 후 복사

    작동 방식

    초기 스타일은 글꼴, 여백 및 패딩을 포함하여 메뉴의 전체 모양을 설정합니다. 기본 표시 속성은 li 요소에 대해 차단으로 설정되어 수평으로 표시되도록 합니다. 드롭다운 하위 메뉴는 표시 속성을 없음으로 설정하여 처음에 숨겨집니다.

    호버 상태는 위치: 절대를 사용하여 하위 메뉴를 상위 항목 아래에 정렬하도록 정의됩니다. 또한 하위 메뉴의 li 및 a 요소는 스타일을 상속하여 일관된 모양을 유지합니다. 하위 하위 메뉴 항목 위로 마우스를 가져가면 배경색이 추가로 변경됩니다.

    결론

    순수한 CSS 드롭다운 메뉴를 만들려면 신중한 HTML 구조화와 사려 깊은 CSS 스타일 지정이 필요합니다. 이러한 기술을 숙달함으로써 웹 디자이너는 사용자 경험을 향상시키고 창의성을 선보이는 우아하고 기능적인 탐색 메뉴의 힘을 발휘할 수 있습니다.

    위 내용은 순수한 CSS 드롭다운 메뉴를 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

  • 본 웹사이트의 성명
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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 옷 제거제

    Video Face Swap

    Video Face Swap

    완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

    뜨거운 도구

    메모장++7.3.1

    메모장++7.3.1

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

    SublimeText3 중국어 버전

    SublimeText3 중국어 버전

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

    스튜디오 13.0.1 보내기

    스튜디오 13.0.1 보내기

    강력한 PHP 통합 개발 환경

    드림위버 CS6

    드림위버 CS6

    시각적 웹 개발 도구

    SublimeText3 Mac 버전

    SublimeText3 Mac 버전

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

    끈적 끈적한 포지셔닝 및 대시 Sass가있는 쌓인 카드 끈적 끈적한 포지셔닝 및 대시 Sass가있는 쌓인 카드 Apr 03, 2025 am 10:30 AM

    다른 날, 나는 Corey Ginnivan의 웹 사이트에서 스크롤 할 때 카드 모음이 서로 쌓이는 것을 발견했습니다.

    Google 글꼴 변수 글꼴 Google 글꼴 변수 글꼴 Apr 09, 2025 am 10:42 AM

    Google Fonts가 새로운 디자인 (트윗)을 출시 한 것을 볼 수 있습니다. 마지막 큰 재 설계와 비교할 때 이것은 훨씬 더 반복적 인 느낌이 듭니다. 차이를 간신히 말할 수 있습니다

    HTML, CSS 및 JavaScript로 애니메이션 카운트 다운 타이머를 만드는 방법 HTML, CSS 및 JavaScript로 애니메이션 카운트 다운 타이머를 만드는 방법 Apr 11, 2025 am 11:29 AM

    프로젝트에 카운트 다운 타이머가 필요한 적이 있습니까? 그런 것은 플러그인에 도달하는 것이 당연하지만 실제로는 훨씬 더 많습니다.

    HTML 데이터 속성 안내서 HTML 데이터 속성 안내서 Apr 11, 2025 am 11:50 AM

    HTML, CSS 및 JavaScript의 데이터 속성에 대해 알고 싶었던 모든 것.

    플렉스 레이아웃의 자주색 슬래시 영역이 잘못된 '오버플로 공간'으로 간주되는 이유는 무엇입니까? 플렉스 레이아웃의 자주색 슬래시 영역이 잘못된 '오버플로 공간'으로 간주되는 이유는 무엇입니까? Apr 05, 2025 pm 05:51 PM

    플렉스 레이아웃의 보라색 슬래시 영역에 대한 질문 플렉스 레이아웃을 사용할 때 개발자 도구 (d ...)와 같은 혼란스러운 현상이 발생할 수 있습니다.

    CSS를 통해 일류 이름 항목으로 자식 요소를 선택하는 방법은 무엇입니까? CSS를 통해 일류 이름 항목으로 자식 요소를 선택하는 방법은 무엇입니까? Apr 05, 2025 pm 11:24 PM

    요소 수가 고정되지 않은 경우 CSS를 통해 지정된 클래스 이름의 첫 번째 자식 요소를 선택하는 방법. HTML 구조를 처리 할 때 종종 다른 요소를 만듭니다 ...

    Sass를 더 빨리 만들기위한 개념 증명 Sass를 더 빨리 만들기위한 개념 증명 Apr 16, 2025 am 10:38 AM

    새로운 프로젝트가 시작될 때, Sass 컴파일은 눈을 깜박이게합니다. 특히 BrowserSync와 짝을 이루는 경우 기분이 좋습니다.

    See all articles