Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.

View in English Always switch to English

PaymentRequestEvent: openWindow() Methode

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.

Hinweis: Diese Funktion ist nur in Service Workers verfügbar.

Die openWindow()-Methode des PaymentRequestEvent-Interfaces öffnet die angegebene URL in einem neuen Fenster, jedoch nur, wenn die gegebene URL im gleichen Ursprung wie die aufrufende Seite liegt. Sie gibt ein Promise zurück, das mit einem Verweis auf einen WindowClient aufgelöst wird.

Syntax

js
openWindow(url)

Parameter

url

Die URL, die im neuen Fenster geöffnet werden soll. Sie muss im gleichen Ursprung wie die aufrufende Seite liegen.

Rückgabewert

Ein Promise, das mit einem Verweis auf einen WindowClient aufgelöst wird.

Beispiele

js
self.addEventListener("paymentrequest", async (e) => {
  // …
  // Retain a promise for future resolution
  // Polyfill for PromiseResolver at link below.
  resolver = new PromiseResolver();

  // Pass a promise that resolves when payment is done.
  e.respondWith(resolver.promise);
  // Open the checkout page.
  try {
    // Open the window and preserve the client
    client = await e.openWindow(checkoutURL);
    if (!client) {
      // Reject if the window fails to open
      throw new Error("Failed to open window");
    }
  } catch (err) {
    // Reject the promise on failure
    resolver.reject(err);
  }
});

Siehe Öffnen des Zahlungsabwicklerfensters zur Anzeige der Web-basierten Zahlungs-App-Frontend für weitere Details zur Verwendung.

Spezifikationen

Specification
Web-based Payment Handler API
# dom-paymentrequestevent-openwindow

Browser-Kompatibilität

Siehe auch