Heim Web-Frontend Front-End-Fragen und Antworten JQuery-Navigation über seitliches Gleiten hinaus

JQuery-Navigation über seitliches Gleiten hinaus

May 28, 2023 pm 04:38 PM

Im modernen Webdesign ist das Navigationsmenü eine sehr wichtige Komponente. Mit der Beliebtheit mobiler Geräte hat die Vielfalt der Bildschirmgrößen zu mehreren Herausforderungen geführt. Wenn ein Navigationsmenü zu viele Elemente enthält, kann es die Breite des Bildschirms überschreiten. Daher ist eine Möglichkeit erforderlich, den Benutzern den Zugriff auf alle Optionen zu ermöglichen. In diesem Artikel stellen wir vor, wie Sie mit jQuery ein horizontal verschiebbares Navigationsmenü implementieren.

Zuerst müssen wir die HTML-Struktur und den HTML-Stil vorbereiten. Das Folgende ist eine grundlegende Navigationsmenüstruktur:

<div class="nav-container">
  <ul class="nav">
    <li><a href="#">Home</a></li>
    <li><a href="#">About Us</a></li>
    <li><a href="#">Products</a></li>
    <li><a href="#">Contact Us</a></li>
    <li><a href="#">Blog</a></li>
    <li><a href="#">FAQs</a></li>
    <li><a href="#">Support</a></li>
    <li><a href="#">Join Us</a></li>
  </ul>
</div>
Nach dem Login kopieren

Wir verwenden CSS, um dieses Navigationsmenü horizontal anzuordnen und ihre Breite und andere Stile festzulegen.

.nav-container {
  overflow-x: scroll;
  white-space: nowrap;
}

.nav {
  display: inline-block;
  list-style-type: none;
  margin: 0;
  padding: 0;
  width: 100%;
}

.nav li {
  display: inline-block;
  text-align: center;
  width: 120px;
}

.nav li a {
  display: block;
  padding: 10px;
  text-decoration: none;
}
Nach dem Login kopieren

Jetzt haben wir das grundlegende HTML und CSS bereit. Als Nächstes verwenden wir jQuery, um das Navigationsmenü horizontal zu verschieben. Wir erstellen einen Effekt, bei dem das Navigationsmenü horizontal verschoben wird, wenn auf die Pfeilschaltfläche geklickt wird.

Zuerst müssen wir einen Click-Event-Handler für die Pfeilschaltfläche hinzufügen. Hier ist ein jQuery-Codeausschnitt, der Klicks auf linke und rechte Pfeiltasten erkennt und das Navigationsmenü basierend auf der Richtung der Pfeiltasten verschiebt:

$('.nav-arrow').on('click', function() {
  var direction = $(this).data('direction');
  var distance = $('.nav li:first-child').outerWidth();

  if (direction === 'prev') {
    $('.nav-container').animate({scrollLeft: '-=' + distance});
  } else {
    $('.nav-container').animate({scrollLeft: '+=' + distance});
  }
});
Nach dem Login kopieren

Wir haben den Pfeiltasten ein Datenrichtungsattribut hinzugefügt, um zwischen links und rechts zu unterscheiden Pfeiltasten. Wenn der Benutzer auf die Pfeilschaltfläche klickt, erkennen wir die Eigenschaft data-direction und verwenden die animate()-Methode von jQuery, um die Position des Navigationsmenüs reibungslos zu verschieben.

Wir können auch einige interaktive Effekte hinzufügen, um das Benutzererlebnis zu verbessern. Wenn der Benutzer beispielsweise das äußerste linke oder rechte Ende des Navigationsmenüs erreicht, können wir die entsprechenden Pfeiltasten deaktivieren.

$('.nav-container').on('scroll', function() {
  var distance = $('.nav li:first-child').outerWidth();
  var scrollLeft = $(this).scrollLeft();

  if (scrollLeft === 0) {
    $('.nav-arrow.prev').addClass('disabled');
  } else {
    $('.nav-arrow.prev').removeClass('disabled');
  }

  if (scrollLeft + distance >= $('.nav').outerWidth()) {
    $('.nav-arrow.next').addClass('disabled');
  } else {
    $('.nav-arrow.next').removeClass('disabled');
  }
});
Nach dem Login kopieren

Wir haben einen Scroll-Event-Handler hinzugefügt, um die Scroll-Position des Navigationsmenüs zu erkennen. Wenn wir ganz nach links scrollen, fügen wir der linken Pfeilschaltfläche eine deaktivierte Klasse hinzu, sodass sie nicht angeklickt werden kann. Ebenso fügen wir die deaktivierte Klasse für die rechte Pfeiltaste hinzu, wenn wir ganz nach rechts scrollen.

Schließlich können wir eine Initialisierungsfunktion hinzufügen, um den Anfangszustand der Pfeiltasten und des Navigationsmenüs festzulegen.

function initNav() {
  var distance = $('.nav li:first-child').outerWidth();
  var navWidth = $('.nav').outerWidth();
  var containerWidth = $('.nav-container').outerWidth();

  if (navWidth > containerWidth) {
    $('.nav-arrow.next').removeClass('disabled');
  }

  $('.nav-arrow').css('top', ($('.nav').outerHeight() / 2 - $('.nav-arrow').outerHeight() / 2));

  $('.nav li').each(function() {
    var itemWidth = $(this).outerWidth();
    if (itemWidth > distance) {
      distance = itemWidth;
    }
  });

  $('.nav li').each(function() {
    $(this).css('width', distance + 'px');
  });
}

initNav();
Nach dem Login kopieren

In der Funktion initNav() ermitteln wir zunächst die Breite des Navigationsmenüs und die Breite des Containers. Wenn die Breite des Navigationsmenüs die Breite des Containers überschreitet, aktivieren wir die rechte Pfeiltaste.

Als nächstes zentrieren wir die Pfeilschaltflächen vertikal und stellen die Navigationsmenüelemente auf die gleiche Breite ein. Da die Breite jedes Menüelements unterschiedlich sein kann, müssen wir die maximale Breite des Menüelements ermitteln und festlegen.

Bisher haben wir jQuery vollständig verwendet, um den horizontalen Gleiteffekt des Navigationsmenüs zu erzielen. Sie können die vollständige Code-Implementierung auf der folgenden JSFiddle anzeigen:

https://jsfiddle.net/36qa5x1t/

Zusammenfassung:

In diesem Artikel wird erläutert, wie Sie mit jQuery den horizontalen Gleiteffekt des Navigationsmenüs erzielen. Wir haben die grundlegende HTML- und CSS-Struktur eingeführt und dieses Navigationsmenü durch das Hinzufügen von Click- und Scroll-Ereignishandlern und einigen interaktiven Effekten verfeinert. Ich hoffe, dass Sie durch diesen Artikel besser verstehen, wie Sie mit jQuery interaktive Effekte auf Webseiten erzielen.

Das obige ist der detaillierte Inhalt vonJQuery-Navigation über seitliches Gleiten hinaus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Reacts Rolle bei HTML: Verbesserung der Benutzererfahrung Reacts Rolle bei HTML: Verbesserung der Benutzererfahrung Apr 09, 2025 am 12:11 AM

React kombiniert JSX und HTML, um die Benutzererfahrung zu verbessern. 1) JSX bettet HTML ein, um die Entwicklung intuitiver zu gestalten. 2) Der virtuelle DOM -Mechanismus optimiert die Leistung und reduziert den DOM -Betrieb. 3) Komponentenbasierte Verwaltungs-Benutzeroberfläche zur Verbesserung der Wartbarkeit. 4) Staatsmanagement und Ereignisverarbeitung verbessern die Interaktivität.

Reagieren und das Frontend: Bauen Sie interaktive Erlebnisse auf Reagieren und das Frontend: Bauen Sie interaktive Erlebnisse auf Apr 11, 2025 am 12:02 AM

React ist das bevorzugte Werkzeug zum Aufbau interaktiver Front-End-Erlebnisse. 1) React vereinfacht die UI -Entwicklung durch Komponentierungen und virtuelles DOM. 2) Komponenten werden in Funktionskomponenten und Klassenkomponenten unterteilt. Funktionskomponenten sind einfacher und Klassenkomponenten bieten mehr Lebenszyklusmethoden. 3) Das Arbeitsprinzip von React beruht auf virtuellen DOM- und Versöhnungsalgorithmus, um die Leistung zu verbessern. 4) State Management verwendet Usestate oder diese. 5) Die grundlegende Verwendung umfasst das Erstellen von Komponenten und das Verwalten von Status, und die erweiterte Verwendung umfasst benutzerdefinierte Haken und Leistungsoptimierung. 6) Zu den häufigen Fehlern gehören unsachgemäße Statusaktualisierungen und Leistungsprobleme, Debugging -Fähigkeiten umfassen die Verwendung von ReactDevtools und exzellent

Reagieren Sie Komponenten: Erstellen wiederverwendbarer Elemente in HTML Reagieren Sie Komponenten: Erstellen wiederverwendbarer Elemente in HTML Apr 08, 2025 pm 05:53 PM

React -Komponenten können durch Funktionen oder Klassen definiert werden, wobei die UI -Logik eingefasst und Eingabedaten durch Props akzeptiert werden. 1) Komponenten definieren: Verwenden Sie Funktionen oder Klassen, um Reaktierungselemente zurückzugeben. 2) Rendering -Komponente: React -Aufrufe rendern Methode oder führt die Funktionskomponente aus. 3) Multiplexing -Komponenten: Daten durch Requisiten übergeben, um eine komplexe Benutzeroberfläche zu erstellen. Mit dem Lebenszyklusansatz von Komponenten kann die Logik in verschiedenen Phasen ausgeführt werden, wodurch die Entwicklungseffizienz und die Wartbarkeit des Codes verbessert werden.

Reagieren Sie und der Frontend Stack: die Werkzeuge und Technologien Reagieren Sie und der Frontend Stack: die Werkzeuge und Technologien Apr 10, 2025 am 09:34 AM

React ist eine JavaScript -Bibliothek zum Erstellen von Benutzeroberflächen mit ihren Kernkomponenten und staatlichen Verwaltung. 1) Vereinfachen Sie die UI -Entwicklung durch Komponentierungen und Staatsmanagement. 2) Das Arbeitsprinzip umfasst Versöhnung und Rendering, und die Optimierung kann durch React.Memo und Usememo implementiert werden. 3) Die grundlegende Verwendung besteht darin, Komponenten zu erstellen und zu rendern, und die erweiterte Verwendung umfasst die Verwendung von Hooks und ContextAPI. 4) Häufige Fehler wie eine unsachgemäße Status -Update können Sie ReactDevtools zum Debuggen verwenden. 5) Die Leistungsoptimierung umfasst die Verwendung von React.

Was sind die Vorteile der Verwendung von TypeScript mit React? Was sind die Vorteile der Verwendung von TypeScript mit React? Mar 27, 2025 pm 05:43 PM

TypeScript verbessert die Reaktionsentwicklung, indem sie die Sicherheit Typ, Verbesserung der Codequalität und eine bessere Unterstützung für eine IDE bietet, wodurch Fehler verringert und die Wartbarkeit verbessert werden.

Wie können Sie den Usereducer für komplexes Staatsmanagement verwenden? Wie können Sie den Usereducer für komplexes Staatsmanagement verwenden? Mar 26, 2025 pm 06:29 PM

In dem Artikel wird der Usereducer für komplexes Zustandsmanagement in React erläutert, wobei die Vorteile gegenüber Usestate detailliert beschrieben werden und wie sie in die Nutzung für Nebenwirkungen integriert werden können.

Reacts Ökosystem: Bibliotheken, Tools und Best Practices Reacts Ökosystem: Bibliotheken, Tools und Best Practices Apr 18, 2025 am 12:23 AM

Das React-Ökosystem umfasst staatliche Verwaltungsbibliotheken (z. B. Redux), Routing-Bibliotheken (z. B. Reactrouter), UI-Komponentenbibliotheken (wie Material-UI), Testwerkzeuge (wie Scherz) und Erstellung von Tools (z. B. Webpack). Diese Tools arbeiten zusammen, um Entwicklern dabei zu helfen, Anwendungen effizient zu entwickeln und zu pflegen, und die Effizienz der Code zu verbessern.

Reagieren gegen Backend Frameworks: Ein Vergleich Reagieren gegen Backend Frameworks: Ein Vergleich Apr 13, 2025 am 12:06 AM

React ist ein Front-End-Framework zum Erstellen von Benutzeroberflächen. Ein Back-End-Framework wird verwendet, um serverseitige Anwendungen zu erstellen. React bietet komponentierte und effiziente UI -Updates, und das Backend -Framework bietet eine vollständige Backend -Service -Lösung. Bei der Auswahl eines Technologie -Stacks sollten Projektanforderungen, Teamfähigkeiten und Skalierbarkeit berücksichtigt werden.

See all articles