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 der PaymentRequestEvent-Schnittstelle öffnet die angegebene URL in einem neuen Fenster, jedoch nur, wenn die angegebene URL den gleichen Ursprung wie die aufrufende Seite hat. Sie gibt ein Promise zurück, das mit einem Verweis auf ein WindowClient aufgelöst wird.

Syntax

js
openWindow(url)

Parameter

url

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

Rückgabewert

Ein Promise, das mit einem Verweis auf ein 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 'Failed to open window';
    }
  } catch (err) {
    // Reject the promise on failure
    resolver.reject(err);
  };
});

Siehe Zahlungsabwickler-Fenster öffnen, um die webbasierte Zahlungs-App-Oberfläche anzuzeigen für weitere Details über die Nutzung.

Spezifikationen

Specification
Payment Handler API
# dom-paymentrequestevent-openwindow

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

Siehe auch