• \n\n \n
    \n\n\n\n

    Key HTML Elements
    \nParticle Background: Provides a subtle, animated effect behind the navbar for a high-end look.
    \nToggle Button: Allows users to expand or collapse the navbar.
    \nNav Items: Each item includes a tooltip, an icon, and some have notification badges.
    \nSelection Indicator: Highlights the active section with a glowing effect.
    \nStep 2: Styling the Navbar with CSS
    \nOur CSS will focus on creating a luxurious, modern design with animated background particles, hover effects, and tooltip displays. Let’s go through each part.<\/p>\n\n

    Base Styles and Background Setup
    \n<\/p>\n\n

    body {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  height: 100vh;\n  margin: 0;\n  background: radial-gradient(circle, #1b1b2f, #121212);\n  font-family: Arial, sans-serif;\n  overflow: hidden;\n  position: relative;\n}\n\n\/* Particle Background *\/\n#particle-background {\n  position: absolute;\n  width: 100%;\n  height: 100%;\n  z-index: 0;\n  background: url('https:\/\/www.transparenttextures.com\/patterns\/dark-matter.png');\n  animation: particleAnimation 30s linear infinite;\n  opacity: 0.3;\n}\n\n@keyframes particleAnimation {\n  0% { background-position: 0 0; }\n  100% { background-position: 1000px 1000px; }\n}\nNavbar Styling\nThe navbar includes a semi-transparent background with a subtle blur effect to achieve a glassy look, which expands and collapses smoothly.\n\ncss\nCopier le code\n.navbar {\n  display: flex;\n  align-items: center;\n  background: rgba(255, 255, 255, 0.1);\n  padding: 15px;\n  border-radius: 40px;\n  backdrop-filter: blur(15px);\n  box-shadow: 0px 10px 30px rgba(0, 0, 0, 0.6);\n  transition: width 0.4s ease, padding 0.4s ease;\n  gap: 15px;\n  width: 60px;\n  overflow: hidden;\n  position: relative;\n  z-index: 1;\n}\n\n.navbar.expanded {\n  width: 360px;\n  padding: 15px 20px;\n  justify-content: flex-start;\n}\n<\/pre>\n\n\n\n

    Toggle Button
    \nThe toggle button expands and collapses the navbar and features a rotating animation on hover.
    \n<\/p>\n\n

    .toggle-button {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  font-size: 24px;\n  color: #ffffff;\n  cursor: pointer;\n  transition: transform 0.3s ease, color 0.3s ease;\n}\n\n.toggle-button:hover {\n  color: #ff00cc;\n  transform: rotate(90deg);\n}\n<\/pre>\n\n\n\n

    Nav Items and Tooltip Effects
    \nEach nav item has a hover effect with a gradient and a glowing background. Tooltips appear with a soft shadow effect to guide users.
    \n<\/p>\n\n

    .nav-item {\n  position: relative;\n  padding: 12px;\n  font-size: 24px;\n  color: #ffffff;\n  cursor: pointer;\n  border-radius: 15px;\n  transition: all 0.3s ease;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background: rgba(255, 255, 255, 0.2);\n  backdrop-filter: blur(10px);\n}\n\n.nav-item:hover {\n  background: linear-gradient(135deg, rgba(255, 0, 204, 0.4), rgba(51, 51, 255, 0.4));\n  transform: translateY(-5px) scale(1.05);\n}\n\n.nav-item::before {\n  content: attr(data-tooltip);\n  position: absolute;\n  bottom: -45px;\n  left: 50%;\n  transform: translateX(-50%);\n  font-size: 12px;\n  color: #ffffff;\n  background: rgba(30, 30, 30, 0.85);\n  padding: 8px 12px;\n  border-radius: 8px;\n  opacity: 0;\n  transition: opacity 0.4s ease, transform 0.4s ease;\n  pointer-events: none;\n  backdrop-filter: blur(8px);\n}\n\n.nav-item:hover::before {\n  opacity: 1;\n  transform: translateY(-8px);\n}\n<\/pre>\n\n\n\n

    Selection Indicator and Notification Badge
    \n<\/p>\n\n

    .selection-indicator {\n  position: absolute;\n  bottom: 10px;\n  height: 4px;\n  width: 30px;\n  background: linear-gradient(90deg, #ff00cc, #3333ff);\n  border-radius: 2px;\n  transition: transform 0.3s ease, width 0.3s ease;\n  z-index: -1;\n}\n\n\/* Notification Badge *\/\n.notification-badge {\n  position: absolute;\n  top: 5px;\n  right: 5px;\n  background: linear-gradient(45deg, #ff0000, #ff4d4d);\n  color: #ffffff;\n  border-radius: 50%;\n  padding: 4px 7px;\n  font-size: 12px;\n  font-weight: bold;\n  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.3);\n  animation: pulse 1.8s infinite ease-in-out;\n}\n<\/pre>\n\n\n\n

    Step 3: Adding JavaScript for Interactivity
    \nJavaScript controls the navbar’s expandable state, the active item, and the selection indicator. It also keeps the indicator aligned with the selected item on resize.
    \n<\/p>\n\n

    const toggleButton = document.querySelector('.toggle-button');\nconst navbar = document.querySelector('.navbar');\nconst navItems = document.querySelectorAll('.nav-item');\nconst selectionIndicator = document.querySelector('.selection-indicator');\n\n\/\/ Toggle the expanded state of the navbar\ntoggleButton.addEventListener('click', () => {\n  navbar.classList.toggle('expanded');\n  toggleButton.querySelector('i').classList.toggle('fa-bars');\n  toggleButton.querySelector('i').classList.toggle('fa-times');\n});\n\n\/\/ Update selection indicator position\nfunction updateSelectionIndicator(activeItem) {\n  const itemRect = activeItem.getBoundingClientRect();\n  const navbarRect = navbar.getBoundingClientRect();\n  const offsetX = itemRect.left - navbarRect.left + navbar.scrollLeft;\n  selectionIndicator.style.transform = `translateX(${offsetX}px)`;\n  selectionIndicator.style.width = `${itemRect.width}px`;\n}\n\n\/\/ Handle nav item selection\nnavItems.forEach((item) => {\n  item.addEventListener('click', () => {\n    navItems.forEach(nav => nav.classList.remove('active'));\n    item.classList.add('active');\n    updateSelectionIndicator(item);\n  });\n});\n\n\/\/ Initialize the position of the selection indicator on page load\ndocument.addEventListener('DOMContentLoaded', () => {\n  const activeItem = document.querySelector('.nav-item.active');\n  if (activeItem) {\n    updateSelectionIndicator(activeItem);\n  }\n});\n<\/pre>\n\n\n\n

    Conclusion
    \nCreating a premium, expandable navbar with dynamic animations and an intuitive interface elevates any web project. With CSS for design and JavaScript for interactivity, we’ve built a flexible component perfect for high-end applications like Gladiators Battle. This navbar's smooth transitions, glowing effects, and expandable functionality provide a professional and modern user experience.<\/p>\n\n

    ? Discover More:<\/p>\n\n

    Explore Gladiators Battle: Dive into the world of ancient warriors and experience strategic gameplay at https:\/\/gladiatorsbattle.com
    \nCheck Out Our GitHub: View code examples and documentation at https:\/\/github.com\/HanGPIErr\/Gladiators-Battle-Documentation
    \nConnect on LinkedIn: Follow me at https:\/\/www.linkedin.com\/in\/pierre-romain-lopez\/
    \nFollow on X: Stay updated on design and gaming projects at https:\/\/x.com\/GladiatorsBT
    \nStay tuned for more tutorials on creating premium web components with HTML, CSS, and JavaScript!<\/p>\n\n\n \n\n \n "}

    国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

    Home Web Front-end JS Tutorial How to Create an Ultra Premium Expandable Navbar with Dynamic Effects and Selection Indicator

    How to Create an Ultra Premium Expandable Navbar with Dynamic Effects and Selection Indicator

    Nov 17, 2024 pm 10:55 PM

    How to Create an Ultra Premium Expandable Navbar with Dynamic Effects and Selection Indicator

    Introduction

    In today’s tutorial, we’ll walk through creating an ultra-premium, expandable navbar with a sleek design, dynamic animations, and modern effects. This advanced navigation bar features:

    An animated particle background for a high-end aesthetic.
    Glowing icons with hover effects.
    A dynamic selection indicator that highlights the active section.
    Smooth animations and transitions for a professional look.
    Built with HTML, CSS, and JavaScript, this navbar is perfect for high-quality web interfaces and enhances the user experience, making it an excellent addition to any project, including interactive games like Gladiators Battle. Let’s dive in!

    Step 1: Setting Up the HTML Structure
    Our expandable navbar uses Font Awesome icons, a toggle button, and custom data-tooltip attributes to provide descriptions for each icon. This markup gives us a flexible structure to build upon.

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <title>Expandable Premium Navbar</title>
      <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css">
      <link rel="stylesheet" href="styles.css">
    </head>
    <body>
    
      <!-- Particle Background -->
      <div>
    
    
    
    <p>Key HTML Elements<br>
    Particle Background: Provides a subtle, animated effect behind the navbar for a high-end look.<br>
    Toggle Button: Allows users to expand or collapse the navbar.<br>
    Nav Items: Each item includes a tooltip, an icon, and some have notification badges.<br>
    Selection Indicator: Highlights the active section with a glowing effect.<br>
    Step 2: Styling the Navbar with CSS<br>
    Our CSS will focus on creating a luxurious, modern design with animated background particles, hover effects, and tooltip displays. Let’s go through each part.</p>
    
    <p>Base Styles and Background Setup<br>
    </p>
    
    <pre class="brush:php;toolbar:false">body {
      display: flex;
      align-items: center;
      justify-content: center;
      height: 100vh;
      margin: 0;
      background: radial-gradient(circle, #1b1b2f, #121212);
      font-family: Arial, sans-serif;
      overflow: hidden;
      position: relative;
    }
    
    /* Particle Background */
    #particle-background {
      position: absolute;
      width: 100%;
      height: 100%;
      z-index: 0;
      background: url('https://www.transparenttextures.com/patterns/dark-matter.png');
      animation: particleAnimation 30s linear infinite;
      opacity: 0.3;
    }
    
    @keyframes particleAnimation {
      0% { background-position: 0 0; }
      100% { background-position: 1000px 1000px; }
    }
    Navbar Styling
    The navbar includes a semi-transparent background with a subtle blur effect to achieve a glassy look, which expands and collapses smoothly.
    
    css
    Copier le code
    .navbar {
      display: flex;
      align-items: center;
      background: rgba(255, 255, 255, 0.1);
      padding: 15px;
      border-radius: 40px;
      backdrop-filter: blur(15px);
      box-shadow: 0px 10px 30px rgba(0, 0, 0, 0.6);
      transition: width 0.4s ease, padding 0.4s ease;
      gap: 15px;
      width: 60px;
      overflow: hidden;
      position: relative;
      z-index: 1;
    }
    
    .navbar.expanded {
      width: 360px;
      padding: 15px 20px;
      justify-content: flex-start;
    }
    

    Toggle Button
    The toggle button expands and collapses the navbar and features a rotating animation on hover.

    .toggle-button {
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 24px;
      color: #ffffff;
      cursor: pointer;
      transition: transform 0.3s ease, color 0.3s ease;
    }
    
    .toggle-button:hover {
      color: #ff00cc;
      transform: rotate(90deg);
    }
    

    Nav Items and Tooltip Effects
    Each nav item has a hover effect with a gradient and a glowing background. Tooltips appear with a soft shadow effect to guide users.

    .nav-item {
      position: relative;
      padding: 12px;
      font-size: 24px;
      color: #ffffff;
      cursor: pointer;
      border-radius: 15px;
      transition: all 0.3s ease;
      display: flex;
      align-items: center;
      justify-content: center;
      background: rgba(255, 255, 255, 0.2);
      backdrop-filter: blur(10px);
    }
    
    .nav-item:hover {
      background: linear-gradient(135deg, rgba(255, 0, 204, 0.4), rgba(51, 51, 255, 0.4));
      transform: translateY(-5px) scale(1.05);
    }
    
    .nav-item::before {
      content: attr(data-tooltip);
      position: absolute;
      bottom: -45px;
      left: 50%;
      transform: translateX(-50%);
      font-size: 12px;
      color: #ffffff;
      background: rgba(30, 30, 30, 0.85);
      padding: 8px 12px;
      border-radius: 8px;
      opacity: 0;
      transition: opacity 0.4s ease, transform 0.4s ease;
      pointer-events: none;
      backdrop-filter: blur(8px);
    }
    
    .nav-item:hover::before {
      opacity: 1;
      transform: translateY(-8px);
    }
    

    Selection Indicator and Notification Badge

    .selection-indicator {
      position: absolute;
      bottom: 10px;
      height: 4px;
      width: 30px;
      background: linear-gradient(90deg, #ff00cc, #3333ff);
      border-radius: 2px;
      transition: transform 0.3s ease, width 0.3s ease;
      z-index: -1;
    }
    
    /* Notification Badge */
    .notification-badge {
      position: absolute;
      top: 5px;
      right: 5px;
      background: linear-gradient(45deg, #ff0000, #ff4d4d);
      color: #ffffff;
      border-radius: 50%;
      padding: 4px 7px;
      font-size: 12px;
      font-weight: bold;
      box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.3);
      animation: pulse 1.8s infinite ease-in-out;
    }
    

    Step 3: Adding JavaScript for Interactivity
    JavaScript controls the navbar’s expandable state, the active item, and the selection indicator. It also keeps the indicator aligned with the selected item on resize.

    const toggleButton = document.querySelector('.toggle-button');
    const navbar = document.querySelector('.navbar');
    const navItems = document.querySelectorAll('.nav-item');
    const selectionIndicator = document.querySelector('.selection-indicator');
    
    // Toggle the expanded state of the navbar
    toggleButton.addEventListener('click', () => {
      navbar.classList.toggle('expanded');
      toggleButton.querySelector('i').classList.toggle('fa-bars');
      toggleButton.querySelector('i').classList.toggle('fa-times');
    });
    
    // Update selection indicator position
    function updateSelectionIndicator(activeItem) {
      const itemRect = activeItem.getBoundingClientRect();
      const navbarRect = navbar.getBoundingClientRect();
      const offsetX = itemRect.left - navbarRect.left + navbar.scrollLeft;
      selectionIndicator.style.transform = `translateX(${offsetX}px)`;
      selectionIndicator.style.width = `${itemRect.width}px`;
    }
    
    // Handle nav item selection
    navItems.forEach((item) => {
      item.addEventListener('click', () => {
        navItems.forEach(nav => nav.classList.remove('active'));
        item.classList.add('active');
        updateSelectionIndicator(item);
      });
    });
    
    // Initialize the position of the selection indicator on page load
    document.addEventListener('DOMContentLoaded', () => {
      const activeItem = document.querySelector('.nav-item.active');
      if (activeItem) {
        updateSelectionIndicator(activeItem);
      }
    });
    

    Conclusion
    Creating a premium, expandable navbar with dynamic animations and an intuitive interface elevates any web project. With CSS for design and JavaScript for interactivity, we’ve built a flexible component perfect for high-end applications like Gladiators Battle. This navbar's smooth transitions, glowing effects, and expandable functionality provide a professional and modern user experience.

    ? Discover More:

    Explore Gladiators Battle: Dive into the world of ancient warriors and experience strategic gameplay at https://gladiatorsbattle.com
    Check Out Our GitHub: View code examples and documentation at https://github.com/HanGPIErr/Gladiators-Battle-Documentation
    Connect on LinkedIn: Follow me at https://www.linkedin.com/in/pierre-romain-lopez/
    Follow on X: Stay updated on design and gaming projects at https://x.com/GladiatorsBT
    Stay tuned for more tutorials on creating premium web components with HTML, CSS, and JavaScript!

    The above is the detailed content of How to Create an Ultra Premium Expandable Navbar with Dynamic Effects and Selection Indicator. For more information, please follow other related articles on the PHP Chinese website!

    Statement of this Website
    The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

    Hot AI Tools

    Undress AI Tool

    Undress AI Tool

    Undress images for free

    Undresser.AI Undress

    Undresser.AI Undress

    AI-powered app for creating realistic nude photos

    AI Clothes Remover

    AI Clothes Remover

    Online AI tool for removing clothes from photos.

    Clothoff.io

    Clothoff.io

    AI clothes remover

    Video Face Swap

    Video Face Swap

    Swap faces in any video effortlessly with our completely free AI face swap tool!

    Hot Tools

    Notepad++7.3.1

    Notepad++7.3.1

    Easy-to-use and free code editor

    SublimeText3 Chinese version

    SublimeText3 Chinese version

    Chinese version, very easy to use

    Zend Studio 13.0.1

    Zend Studio 13.0.1

    Powerful PHP integrated development environment

    Dreamweaver CS6

    Dreamweaver CS6

    Visual web development tools

    SublimeText3 Mac version

    SublimeText3 Mac version

    God-level code editing software (SublimeText3)

    Which Comment Symbols to Use in JavaScript: A Clear Explanation Which Comment Symbols to Use in JavaScript: A Clear Explanation Jun 12, 2025 am 10:27 AM

    In JavaScript, choosing a single-line comment (//) or a multi-line comment (//) depends on the purpose and project requirements of the comment: 1. Use single-line comments for quick and inline interpretation; 2. Use multi-line comments for detailed documentation; 3. Maintain the consistency of the comment style; 4. Avoid over-annotation; 5. Ensure that the comments are updated synchronously with the code. Choosing the right annotation style can help improve the readability and maintainability of your code.

    Java vs. JavaScript: Clearing Up the Confusion Java vs. JavaScript: Clearing Up the Confusion Jun 20, 2025 am 12:27 AM

    Java and JavaScript are different programming languages, each suitable for different application scenarios. Java is used for large enterprise and mobile application development, while JavaScript is mainly used for web page development.

    Javascript Comments: short explanation Javascript Comments: short explanation Jun 19, 2025 am 12:40 AM

    JavaScriptcommentsareessentialformaintaining,reading,andguidingcodeexecution.1)Single-linecommentsareusedforquickexplanations.2)Multi-linecommentsexplaincomplexlogicorprovidedetaileddocumentation.3)Inlinecommentsclarifyspecificpartsofcode.Bestpractic

    Mastering JavaScript Comments: A Comprehensive Guide Mastering JavaScript Comments: A Comprehensive Guide Jun 14, 2025 am 12:11 AM

    CommentsarecrucialinJavaScriptformaintainingclarityandfosteringcollaboration.1)Theyhelpindebugging,onboarding,andunderstandingcodeevolution.2)Usesingle-linecommentsforquickexplanationsandmulti-linecommentsfordetaileddescriptions.3)Bestpracticesinclud

    JavaScript Data Types: A Deep Dive JavaScript Data Types: A Deep Dive Jun 13, 2025 am 12:10 AM

    JavaScripthasseveralprimitivedatatypes:Number,String,Boolean,Undefined,Null,Symbol,andBigInt,andnon-primitivetypeslikeObjectandArray.Understandingtheseiscrucialforwritingefficient,bug-freecode:1)Numberusesa64-bitformat,leadingtofloating-pointissuesli

    JavaScript vs. Java: A Comprehensive Comparison for Developers JavaScript vs. Java: A Comprehensive Comparison for Developers Jun 20, 2025 am 12:21 AM

    JavaScriptispreferredforwebdevelopment,whileJavaisbetterforlarge-scalebackendsystemsandAndroidapps.1)JavaScriptexcelsincreatinginteractivewebexperienceswithitsdynamicnatureandDOMmanipulation.2)Javaoffersstrongtypingandobject-orientedfeatures,idealfor

    How to work with dates and times in js? How to work with dates and times in js? Jul 01, 2025 am 01:27 AM

    The following points should be noted when processing dates and time in JavaScript: 1. There are many ways to create Date objects. It is recommended to use ISO format strings to ensure compatibility; 2. Get and set time information can be obtained and set methods, and note that the month starts from 0; 3. Manually formatting dates requires strings, and third-party libraries can also be used; 4. It is recommended to use libraries that support time zones, such as Luxon. Mastering these key points can effectively avoid common mistakes.

    JavaScript: Exploring Data Types for Efficient Coding JavaScript: Exploring Data Types for Efficient Coding Jun 20, 2025 am 12:46 AM

    JavaScripthassevenfundamentaldatatypes:number,string,boolean,undefined,null,object,andsymbol.1)Numbersuseadouble-precisionformat,usefulforwidevaluerangesbutbecautiouswithfloating-pointarithmetic.2)Stringsareimmutable,useefficientconcatenationmethodsf

    See all articles