From 0ebbcc2b872bad5babd4b8250f286868327c7214 Mon Sep 17 00:00:00 2001 From: sammy0318 Date: Sun, 22 Dec 2024 21:28:54 +0530 Subject: [PATCH] updated js --- Garima.js | 59 ++++++++++++++++++++++++++++--------------------------- 1 file changed, 30 insertions(+), 29 deletions(-) diff --git a/Garima.js b/Garima.js index a95e57a..0fe695a 100644 --- a/Garima.js +++ b/Garima.js @@ -1,43 +1,44 @@ -// Smooth scroll effect for navigation links -document.querySelectorAll('a[href^="#"]').forEach(anchor => { - anchor.addEventListener('click', function(e) { - e.preventDefault(); - - document.querySelector(this.getAttribute('href')).scrollIntoView({ - behavior: 'smooth' - }); - }); -}); - -// Responsive menu toggle +// Select DOM elements const menuToggle = document.querySelector('.menu-toggle'); const navLinks = document.querySelector('.nav-links'); +const scrollToTopBtn = document.querySelector('.scroll-to-top'); // Make sure you have this element in your HTML +// Toggle mobile menu menuToggle.addEventListener('click', () => { navLinks.classList.toggle('open'); + // Optional: Toggle aria-expanded attribute for accessibility + menuToggle.setAttribute( + 'aria-expanded', + menuToggle.getAttribute('aria-expanded') === 'false' ? 'true' : 'false' + ); }); - -// Smooth Scrolling +// Smooth scroll for all anchor links document.querySelectorAll('a[href^="#"]').forEach(anchor => { anchor.addEventListener('click', function(e) { e.preventDefault(); - - document.querySelector(this.getAttribute('href')).scrollIntoView({ - behavior: 'smooth' - }); + const targetElement = document.querySelector(this.getAttribute('href')); + + if (targetElement) { + targetElement.scrollIntoView({ + behavior: 'smooth' + }); + + // Close mobile menu when a link is clicked + if (navLinks.classList.contains('open')) { + navLinks.classList.remove('open'); + menuToggle.setAttribute('aria-expanded', 'false'); + } + } }); }); - - -scrollToTopBtn.addEventListener('click', () => { - window.scrollTo({ top: 0, behavior: 'smooth' }); -}); - -// Close mobile menu when a nav link is clicked -navLinks.querySelectorAll('a').forEach(link => { - link.addEventListener('click', () => { - navLinks.classList.remove('open'); +// Scroll to top functionality +if (scrollToTopBtn) { + scrollToTopBtn.addEventListener('click', () => { + window.scrollTo({ + top: 0, + behavior: 'smooth' + }); }); -}); \ No newline at end of file +} \ No newline at end of file