Was ist Pjax

Nov 22, 2016 pm 01:46 PM
ajax js pjax

Was ist pjax?

Viele Websites (Facebook, Twitter) unterstützen mittlerweile eine solche Browsing-Methode. Wenn Sie auf einen Link innerhalb der Website klicken, wird nicht zur Seite gesprungen, sondern nur innerhalb der Website . Die Seite wird aktualisiert. Diese Art von Benutzererfahrung ist viel besser, als wenn die gesamte Seite blinkt.

Es gibt einen sehr wichtigen Teil der Ajax-Aktualisierung dieser Websites. Beim Aktualisieren der Seite ändert sich auch die Adresse im Browser-Adressfeld der vorherigen Seite.

Wenn wir also eine solche Funktion implementieren wollen, wie machen wir das?

Ich habe festgestellt, dass pjax ein Skript zur Unterstützung dieser Funktionalität bereitstellt.

Die Pjax-Projektadresse lautet https://github.com/defunkt/jquery-pjax. Den tatsächlichen Effekt finden Sie unter: http://pjax.heroku.com/ Wenn pjax nicht aktiviert ist, wird durch Klicken auf den Link ein Sprung ausgeführt. Nach der Überprüfung werden die Links per Ajax aktualisiert.

Warum pjax verwenden?

pjax hat mehrere Vorteile:

Verbesserung der Benutzererfahrung. Wenn die Seite springt, muss das menschliche Auge die gesamte Seite neu identifizieren. Beim Aktualisieren eines Teils der Seite muss nur ein Bereich neu identifiziert werden. Da ich auf meiner Website die Pjax-Technologie verwendet habe, habe ich das Gefühl, dass es viel unangenehmer ist, andere Websites zu besuchen, die nur Seitensprünge haben. Da beim Aktualisieren einiger Seiten eine Ladeaufforderung angezeigt wird und die alte Seite beim Aktualisieren weiterhin im Browser angezeigt wird, können Benutzer gleichzeitig längere Seitenladezeiten tolerieren.

Reduzieren Sie den Bandbreitenverbrauch und den Serververbrauch erheblich. Da nur ein Teil der Seite aktualisiert wird, werden die meisten Anforderungen (CSS/JS) nicht erneut abgerufen und der äußere Rahmen der Website mit Benutzeranmeldeinformationen muss nicht neu generiert werden. Obwohl ich den Verbrauch dieses Teils nicht speziell gezählt habe, schätze ich, dass mindestens 40 % der Anfragen und mehr als 30 % des Serververbrauchs eingespart wurden.

Ich denke, es gibt auch Nachteile:

Obwohl ich die Unterstützung historischer Browser wie IE6 nicht wirklich getestet habe, wird es Probleme mit der Kompatibilität mit älteren Browsern geben, da pjax neue Standards verwendet. Pjax selbst unterstützt jedoch den Fallback. Wenn festgestellt wird, dass der Browser diese Funktion nicht unterstützt, springt er zur Originalseite zurück.

Komplexe serverseitige Unterstützung: Die Serverseite muss basierend auf eingehenden Anforderungen bestimmen, ob eine vollständige Seitenwiedergabe oder eine teilweise Seitenwiedergabe durchgeführt werden soll. Bei gut gestaltetem Servercode sollte die Unterstützung dieser Funktionalität jedoch kein großes Problem darstellen.

In der Summe können durch die Verbesserung des Benutzererlebnisses und der Ressourcenauslastung die Nachteile vollständig ausgeglichen werden. Ich kann jedem nur wärmstens empfehlen, es zu verwenden.

Wie verwende ich pjax?

Schauen Sie sich einfach die offizielle Dokumentation an.

Ich denke, Techniker sollten sich angewöhnen, technische Informationen aus erster Hand zu lesen.

Es gibt ein Rails-Gem-Plugin für Pjax, das direkt verwendet werden kann. Es gibt auch Django-Unterstützung.

Prinzipien von pjax

Um mit Problemen umgehen zu können, müssen wir verstehen, wie pjax funktioniert. Der Pjax-Code hat nur eine Datei: https://github.com/defunkt/jquery-pjax/blob/master/jquery.pjax.js

Wenn Sie die Möglichkeit dazu haben, können Sie einen Blick darauf werfen selbst. Lassen Sie mich das Prinzip hier erklären.

Zuerst geben wir im HTML an, welcher Linkinhalt pjaxiert werden muss und welcher Teil nach dem Klicken aktualisiert werden muss (fügen Sie ihn in das data-pjax-Attribut ein):

$('a[data-pjax]').pjax()
Nach dem Login kopieren

Wenn das Pjax-Skript geladen wurde, fängt es die Ereignisse dieser Links ab, packt sie dann in eine Ajax-Anfrage und sendet sie an den Server.

$.fn.pjax = function( container, options ) {
  return this.live('click.pjax', function(event){
    handleClick(event, container, options)
  })
}
function handleClick(event, container, options) {
  $.pjax($.extend({}, defaults, options))
  ...
  event.preventDefault()
}
var pjax = $.pjax = function( options ) {
  ...
  pjax.xhr = $.ajax(options)
}
Nach dem Login kopieren

Diese Anfrage trägt die HEADER-Kennung von X-PJAX. Wenn der Server eine solche Anfrage erhält, weiß er, dass er nur einen Teil der Seite rendern und zurückgeben muss.

xhr.setRequestHeader('X-PJAX', 'true')
xhr.setRequestHeader('X-PJAX-Container', context.selector)
Nach dem Login kopieren

Nachdem pjax die zurückgegebene Anfrage erhalten hat, aktualisiert es den von data-pjax angegebenen Bereich und aktualisiert auch die Adresse des Browsers.

options.success = function(data, status, xhr) {
  var container = extractContainer(data, xhr, options)
  ...
  if (container.title) document.title = container.title
  context.html(container.contents)
}
Nach dem Login kopieren

Um den Rückzug des Browsers zu unterstützen, wird die Verlaufs-API verwendet, um die entsprechenden Informationen aufzuzeichnen.

pjax.state = {
  id: options.id || uniqueId(),
  url: container.url,
  container: context.selector,
  fragment: options.fragment,
  timeout: options.timeout
}
if (options.push || options.replace) {
  window.history.replaceState(pjax.state, container.title, container.url)
}
Nach dem Login kopieren

Wenn sich der Browser zurückzieht, wird das Ereignis abgefangen und aufgezeichnet Informationen, generieren Sie eine neue Ajax-Anfrage.

$(window).bind('popstate', function(event){
  var state = event.state
  if (state && state.container) {
    var container = $(state.container)
    if (container.length) {
      ...
      var options = {
        id: state.id,
        url: state.url,
        container: container,
        push: false,
        fragment: state.fragment,
        timeout: state.timeout,
        scrollTo: false
      }
      if (contents) {
        // pjax event is deprecated
        $(document).trigger('pjax', [null, options])
        container.trigger('pjax:start', [null, options])
        // end.pjax event is deprecated
        container.trigger('start.pjax', [null, options])
        container.html(contents)
        pjax.state = state
        container.trigger('pjax:end', [null, options])
        // end.pjax event is deprecated
        container.trigger('end.pjax', [null, options])
      } else {
        $.pjax(options)
      }
      ...
    }
  }
}
Nach dem Login kopieren

Um Fallback zu unterstützen, muss zum einen festgestellt werden, ob der Browser beim Laden die History-Pushstate-API unterstützt:

// Is pjax supported by this browser?
$.support.pjax =
  window.history && window.history.pushState && window.history.replaceState
  // pushState isn't reliable on iOS until 5.
  && !navigator.userAgent.match(/((iPod|iPhone|iPad).+\bOS\s+[1-4]|WebApps\/.+CFNetwork)/)
Nach dem Login kopieren

Die andere besteht darin, festzustellen, ob die Anforderung vorhanden ist Wenn eine bestimmte Zeit lang nicht auf eine Antwort geantwortet wurde (Sie können den Parameter „Timeout“ festlegen), können Sie direkt zur Seite springen.

options.beforeSend = function(xhr, settings) {
  if (settings.timeout > 0) {
    timeoutTimer = setTimeout(function() {
      if (fire('pjax:timeout', [xhr, options]))
        xhr.abort('timeout')
    }, settings.timeout)
    // Clear timeout setting so jquerys internal timeout isn't invoked
    settings.timeout = 0
Nach dem Login kopieren

Fazit

Nachdem Sie das gesehen haben, warum verwenden Sie nicht tatsächlich pjax? Es gibt so viele Vorteile, dass ich denke, dass fast alle Websites pjax verwenden sollten. Nutzen Sie es jetzt!


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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

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)

Empfohlen: Ausgezeichnetes JS-Open-Source-Projekt zur Gesichtserkennung und -erkennung Empfohlen: Ausgezeichnetes JS-Open-Source-Projekt zur Gesichtserkennung und -erkennung Apr 03, 2024 am 11:55 AM

Die Technologie zur Gesichtserkennung und -erkennung ist bereits eine relativ ausgereifte und weit verbreitete Technologie. Derzeit ist JS die am weitesten verbreitete Internetanwendungssprache. Die Implementierung der Gesichtserkennung und -erkennung im Web-Frontend hat im Vergleich zur Back-End-Gesichtserkennung Vor- und Nachteile. Zu den Vorteilen gehören die Reduzierung der Netzwerkinteraktion und die Echtzeiterkennung, was die Wartezeit des Benutzers erheblich verkürzt und das Benutzererlebnis verbessert. Die Nachteile sind: Es ist durch die Größe des Modells begrenzt und auch die Genauigkeit ist begrenzt. Wie implementiert man mit js die Gesichtserkennung im Web? Um die Gesichtserkennung im Web zu implementieren, müssen Sie mit verwandten Programmiersprachen und -technologien wie JavaScript, HTML, CSS, WebRTC usw. vertraut sein. Gleichzeitig müssen Sie auch relevante Technologien für Computer Vision und künstliche Intelligenz beherrschen. Dies ist aufgrund des Designs der Webseite erwähnenswert

So beheben Sie den 403-Fehler, der bei einer jQuery-AJAX-Anfrage auftritt So beheben Sie den 403-Fehler, der bei einer jQuery-AJAX-Anfrage auftritt Feb 20, 2024 am 10:07 AM

Titel: Methoden und Codebeispiele zur Behebung von 403-Fehlern in jQuery-AJAX-Anfragen. Der 403-Fehler bezieht sich auf eine Anfrage, dass der Server den Zugriff auf eine Ressource verbietet. Dieser Fehler tritt normalerweise auf, weil der Anfrage die Berechtigungen fehlen oder sie vom Server abgelehnt wird. Wenn Sie jQueryAJAX-Anfragen stellen, stoßen Sie manchmal auf diese Situation. In diesem Artikel wird erläutert, wie dieses Problem gelöst werden kann, und es werden Codebeispiele bereitgestellt. Lösung: Berechtigungen prüfen: Stellen Sie zunächst sicher, dass die angeforderte URL-Adresse korrekt ist und stellen Sie sicher, dass Sie über ausreichende Berechtigungen für den Zugriff auf die Ressource verfügen.

So beheben Sie den Fehler 403 der jQuery AJAX-Anfrage So beheben Sie den Fehler 403 der jQuery AJAX-Anfrage Feb 19, 2024 pm 05:55 PM

jQuery ist eine beliebte JavaScript-Bibliothek zur Vereinfachung der clientseitigen Entwicklung. AJAX ist eine Technologie, die asynchrone Anfragen sendet und mit dem Server interagiert, ohne die gesamte Webseite neu zu laden. Wenn Sie jedoch jQuery zum Senden von AJAX-Anfragen verwenden, treten manchmal 403-Fehler auf. Bei 403-Fehlern handelt es sich in der Regel um vom Server verweigerte Zugriffsfehler, möglicherweise aufgrund von Sicherheitsrichtlinien oder Berechtigungsproblemen. In diesem Artikel besprechen wir, wie Sie bei einer jQueryAJAX-Anfrage den Fehler 403 beheben können

Wie erhalte ich Variablen aus der PHP-Methode mit Ajax? Wie erhalte ich Variablen aus der PHP-Methode mit Ajax? Mar 09, 2024 pm 05:36 PM

Die Verwendung von Ajax zum Abrufen von Variablen aus PHP-Methoden ist ein häufiges Szenario in der Webentwicklung. Durch Ajax kann die Seite dynamisch abgerufen werden, ohne dass die Daten aktualisiert werden müssen. In diesem Artikel stellen wir vor, wie man Ajax verwendet, um Variablen aus PHP-Methoden abzurufen, und stellen spezifische Codebeispiele bereit. Zuerst müssen wir eine PHP-Datei schreiben, um die Ajax-Anfrage zu verarbeiten und die erforderlichen Variablen zurückzugeben. Hier ist ein Beispielcode für eine einfache PHP-Datei getData.php:

Wie kann das Problem des jQuery AJAX-Fehlers 403 gelöst werden? Wie kann das Problem des jQuery AJAX-Fehlers 403 gelöst werden? Feb 23, 2024 pm 04:27 PM

Wie kann das Problem des jQueryAJAX-Fehlers 403 gelöst werden? Bei der Entwicklung von Webanwendungen wird jQuery häufig zum Senden asynchroner Anfragen verwendet. Allerdings kann bei der Verwendung von jQueryAJAX manchmal der Fehlercode 403 auftreten, der darauf hinweist, dass der Zugriff vom Server verboten ist. Dies wird normalerweise durch serverseitige Sicherheitseinstellungen verursacht, es gibt jedoch Möglichkeiten, das Problem zu beheben. In diesem Artikel wird erläutert, wie Sie das Problem des jQueryAJAX-Fehlers 403 lösen können, und es werden spezifische Codebeispiele bereitgestellt. 1. machen

PHP und Ajax: Erstellen einer Autovervollständigungs-Vorschlags-Engine PHP und Ajax: Erstellen einer Autovervollständigungs-Vorschlags-Engine Jun 02, 2024 pm 08:39 PM

Erstellen Sie eine Engine für Autovervollständigungsvorschläge mit PHP und Ajax: Serverseitiges Skript: Verarbeitet Ajax-Anfragen und gibt Vorschläge zurück (autocomplete.php). Client-Skript: Ajax-Anfrage senden und Vorschläge anzeigen (autocomplete.js). Praktischer Fall: Fügen Sie ein Skript in die HTML-Seite ein und geben Sie die Kennung des Sucheingabeelements an.

Die Beziehung zwischen js und vue Die Beziehung zwischen js und vue Mar 11, 2024 pm 05:21 PM

Die Beziehung zwischen js und vue: 1. JS als Eckpfeiler der Webentwicklung; 2. Der Aufstieg von Vue.js als Front-End-Framework; 3. Die komplementäre Beziehung zwischen JS und Vue; Vue.

PHP vs. Ajax: Lösungen zum Erstellen dynamisch geladener Inhalte PHP vs. Ajax: Lösungen zum Erstellen dynamisch geladener Inhalte Jun 06, 2024 pm 01:12 PM

Ajax (Asynchronous JavaScript and XML) ermöglicht das Hinzufügen dynamischer Inhalte, ohne die Seite neu laden zu müssen. Mit PHP und Ajax können Sie eine Produktliste dynamisch laden: HTML erstellt eine Seite mit einem Containerelement und die Ajax-Anfrage fügt die Daten nach dem Laden zum Element hinzu. JavaScript verwendet Ajax, um über XMLHttpRequest eine Anfrage an den Server zu senden, um Produktdaten im JSON-Format vom Server abzurufen. PHP nutzt MySQL, um Produktdaten aus der Datenbank abzufragen und in das JSON-Format zu kodieren. JavaScript analysiert die JSON-Daten und zeigt sie im Seitencontainer an. Durch Klicken auf die Schaltfläche wird eine Ajax-Anfrage zum Laden der Produktliste ausgelöst.

See all articles