NavigateEvent: canIntercept-Eigenschaft

Limited availability

This feature is not Baseline because it does not work in some of the most widely-used browsers.

Experimentell: Dies ist eine experimentelle Technologie
Überprüfen Sie die Browser-Kompatibilitätstabelle sorgfältig vor der Verwendung auf produktiven Webseiten.

Die schreibgeschützte Eigenschaft canIntercept des NavigateEvent-Interfaces gibt true zurück, wenn die Navigation abgefangen und die URL umgeschrieben werden kann, oder false andernfalls.

Es gibt mehrere Regeln dafür, wann eine Navigation abgefangen werden kann. Zum Beispiel:

  • Sie können keine Cross-Origin-Navigationen abfangen.
  • Sie können http- oder https-URLs abfangen, wenn sich nur die path-, query- und fragment-Teile der neuen URL von der aktuellen URL unterscheiden.
  • Sie können file-URLs abfangen, wenn sich nur die query- und fragment-Teile der neuen URL unterscheiden.
  • Bei anderen URL-Typen können Sie die Navigation abfangen, wenn sich nur der fragment-Teil unterscheidet.

Siehe die Spezifikation für eine genauere Erklärung, wann ein Dokument seine URL umgeschrieben haben kann, einschließlich einer Tabelle mit Beispielen.

Wert

Ein boolescher Wert—true, wenn die Navigation abgefangen werden kann, false, wenn nicht.

Beispiele

js
navigation.addEventListener("navigate", (event) => {
  // Some navigations, e.g. cross-origin navigations, we
  // cannot intercept. Let the browser handle those normally.
  if (!event.canIntercept) {
    return;
  }

  // Don't intercept fragment navigations or downloads.
  if (event.hashChange || event.downloadRequest !== null) {
    return;
  }

  event.intercept({
    handler() {
      if (event.formData) {
        processFormDataAndUpdateUI(event.formData, event.signal);
      } else {
        doSinglePageAppNav(event.destination, event.signal);
      }
    },
  });
});

Spezifikationen

Specification
HTML
# dom-navigateevent-canintercept-dev

Browser-Kompatibilität

Report problems with this compatibility data on GitHub
desktopmobile
Chrome
Edge
Firefox
Opera
Safari
Chrome Android
Firefox for Android
Opera Android
Safari on iOS
Samsung Internet
WebView Android
WebView on iOS
canIntercept
Experimental

Legend

Tip: you can click/tap on a cell for more information.

Full support
Full support
No support
No support
Experimental. Expect behavior to change in the future.
Uses a non-standard name.
Has more compatibility info.

Siehe auch