<span id="bo5r9"></span>

\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