suchen

Was ist Pjax

Nov 22, 2016 pm 01:46 PM
ajaxjspjax

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()

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)
}

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)

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)
}

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)
}

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)
      }
      ...
    }
  }
}

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)/)

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

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!


Stellungnahme
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
Erstellen einer SaaS-Anwendung mit mehreren Mietern mit Next.js (Backend Integration)Erstellen einer SaaS-Anwendung mit mehreren Mietern mit Next.js (Backend Integration)Apr 11, 2025 am 08:23 AM

Ich habe eine funktionale SaaS-Anwendung mit mehreren Mandanten (eine EdTech-App) mit Ihrem täglichen Tech-Tool erstellt und Sie können dasselbe tun. Was ist eine SaaS-Anwendung mit mehreren Mietern? Mit Multi-Tenant-SaaS-Anwendungen können Sie mehrere Kunden aus einem Sing bedienen

So erstellen Sie eine SaaS-Anwendung mit mehreren Mietern mit Next.js (Frontend Integration)So erstellen Sie eine SaaS-Anwendung mit mehreren Mietern mit Next.js (Frontend Integration)Apr 11, 2025 am 08:22 AM

Dieser Artikel zeigt die Frontend -Integration mit einem Backend, das durch die Genehmigung gesichert ist und eine funktionale edtech SaaS -Anwendung unter Verwendung von Next.js. erstellt. Die Frontend erfasst Benutzerberechtigungen zur Steuerung der UI-Sichtbarkeit und stellt sicher, dass API-Anfragen die Rollenbasis einhalten

JavaScript: Erforschung der Vielseitigkeit einer WebspracheJavaScript: Erforschung der Vielseitigkeit einer WebspracheApr 11, 2025 am 12:01 AM

JavaScript ist die Kernsprache der modernen Webentwicklung und wird für seine Vielfalt und Flexibilität häufig verwendet. 1) Front-End-Entwicklung: Erstellen Sie dynamische Webseiten und einseitige Anwendungen durch DOM-Operationen und moderne Rahmenbedingungen (wie React, Vue.js, Angular). 2) Serverseitige Entwicklung: Node.js verwendet ein nicht blockierendes E/A-Modell, um hohe Parallelitäts- und Echtzeitanwendungen zu verarbeiten. 3) Entwicklung von Mobil- und Desktop-Anwendungen: Die plattformübergreifende Entwicklung wird durch reaktnative und elektronen zur Verbesserung der Entwicklungseffizienz realisiert.

Die Entwicklung von JavaScript: Aktuelle Trends und ZukunftsaussichtenDie Entwicklung von JavaScript: Aktuelle Trends und ZukunftsaussichtenApr 10, 2025 am 09:33 AM

Zu den neuesten Trends im JavaScript gehören der Aufstieg von Typenkripten, die Popularität moderner Frameworks und Bibliotheken und die Anwendung der WebAssembly. Zukunftsaussichten umfassen leistungsfähigere Typsysteme, die Entwicklung des serverseitigen JavaScript, die Erweiterung der künstlichen Intelligenz und des maschinellen Lernens sowie das Potenzial von IoT und Edge Computing.

Entmystifizieren JavaScript: Was es tut und warum es wichtig istEntmystifizieren JavaScript: Was es tut und warum es wichtig istApr 09, 2025 am 12:07 AM

JavaScript ist der Eckpfeiler der modernen Webentwicklung. Zu den Hauptfunktionen gehören eine ereignisorientierte Programmierung, die Erzeugung der dynamischen Inhalte und die asynchrone Programmierung. 1) Ereignisgesteuerte Programmierung ermöglicht es Webseiten, sich dynamisch entsprechend den Benutzeroperationen zu ändern. 2) Die dynamische Inhaltsgenerierung ermöglicht die Anpassung der Seiteninhalte gemäß den Bedingungen. 3) Asynchrone Programmierung stellt sicher, dass die Benutzeroberfläche nicht blockiert ist. JavaScript wird häufig in der Webinteraktion, der einseitigen Anwendung und der serverseitigen Entwicklung verwendet, wodurch die Flexibilität der Benutzererfahrung und die plattformübergreifende Entwicklung erheblich verbessert wird.

Ist Python oder JavaScript besser?Ist Python oder JavaScript besser?Apr 06, 2025 am 12:14 AM

Python eignet sich besser für Datenwissenschaft und maschinelles Lernen, während JavaScript besser für die Entwicklung von Front-End- und Vollstapel geeignet ist. 1. Python ist bekannt für seine prägnante Syntax- und Rich -Bibliotheks -Ökosystems und ist für die Datenanalyse und die Webentwicklung geeignet. 2. JavaScript ist der Kern der Front-End-Entwicklung. Node.js unterstützt die serverseitige Programmierung und eignet sich für die Entwicklung der Vollstapel.

Wie installiere ich JavaScript?Wie installiere ich JavaScript?Apr 05, 2025 am 12:16 AM

JavaScript erfordert keine Installation, da es bereits in moderne Browser integriert ist. Sie benötigen nur einen Texteditor und einen Browser, um loszulegen. 1) Führen Sie sie in der Browser -Umgebung durch, indem Sie die HTML -Datei durch Tags einbetten. 2) Führen Sie die JavaScript -Datei nach dem Herunterladen und Installieren von node.js nach dem Herunterladen und Installieren der Befehlszeile aus.

Wie sende ich Benachrichtigungen, bevor eine Aufgabe in Quartz beginnt?Wie sende ich Benachrichtigungen, bevor eine Aufgabe in Quartz beginnt?Apr 04, 2025 pm 09:24 PM

So senden Sie im Voraus Aufgabenbenachrichtigungen in Quartz Wenn der Quartz -Timer eine Aufgabe plant, wird die Ausführungszeit der Aufgabe durch den Cron -Ausdruck festgelegt. Jetzt...

See all articles

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 vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

SAP NetWeaver Server-Adapter für Eclipse

SAP NetWeaver Server-Adapter für Eclipse

Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung