Web Share API
Sicherer Kontext: Diese Funktion ist nur in sicheren Kontexten (HTTPS) in einigen oder allen unterstützenden Browsern verfügbar.
Die Web Share API bietet einen Mechanismus zum Teilen von Text, Links, Dateien und anderen Inhalten an ein beliebiges, vom Benutzer ausgewähltes Share-Ziel.
Hinweis: Diese API ist nicht verfügbar in Web Workers (nicht über WorkerNavigator
zugänglich).
Hinweis: Diese API sollte nicht mit der Web Share Target API verwechselt werden, die es einer Website ermöglicht, sich selbst als Share-Ziel anzugeben.
Konzepte und Verwendung
Die Web Share API ermöglicht es einer Website, Text, Links, Dateien und andere Inhalte an vom Benutzer ausgewählte Share-Ziele zu teilen, indem die Freigabemechanismen des zugrunde liegenden Betriebssystems genutzt werden. Diese Share-Ziele umfassen typischerweise die Systemzwischenablage, E-Mail, Kontakte oder Messaging-Anwendungen sowie Bluetooth- oder Wi-Fi-Kanäle.
Die API verfügt über lediglich zwei Methoden.
Die navigator.canShare()
-Methode kann verwendet werden, um zunächst zu validieren, ob einige Daten "teilbar" sind, bevor sie zum Versenden an navigator.share()
übergeben werden.
Die navigator.share()
-Methode ruft den nativen Freigabemechanismus des zugrunde liegenden Betriebssystems auf und übergibt die angegebenen Daten.
Sie erfordert eine transiente Aktivierung und muss daher durch ein UI-Ereignis wie einen Klick auf einen Button ausgelöst werden.
Darüber hinaus muss die Methode gültige Daten angeben, die durch die native Implementierung zum Teilen unterstützt werden.
Die Web Share API wird durch die web-share Permissions Policy gesteuert. Wenn die Policy unterstützt wird, aber nicht gewährt wurde, werden beide Methoden anzeigen, dass die Daten nicht teilbar sind.
Schnittstellen
Erweiterungen zu anderen Schnittstellen
-
Gibt einen Boolean zurück, der angibt, ob die angegebenen Daten teilbar sind.
-
Gibt ein
Promise
zurück, das aufgelöst wird, wenn die übergebenen Daten erfolgreich an ein Share-Ziel gesendet wurden. Diese Methode muss bei einem Klick auf einen Button oder eine andere Benutzeraktivierung aufgerufen werden (erfordert transiente Aktivierung).
Beispiel
Der folgende Code zeigt, wie Sie einen Link mit navigator.share()
teilen können, ausgelöst durch einen Klick auf einen Button.
const shareData = {
title: "MDN",
text: "Learn web development on MDN!",
url: "https://developer.mozilla.org",
};
const btn = document.querySelector("button");
const resultPara = document.querySelector(".result");
// Share must be triggered by "user activation"
btn.addEventListener("click", async () => {
try {
await navigator.share(shareData);
resultPara.textContent = "MDN shared successfully";
} catch (err) {
resultPara.textContent = `Error: ${err}`;
}
});
Das obige Beispiel stammt aus unserem Web share test (siehe den Quellcode). Sie können dies auch als Live-Beispiel in navigator.share()
sehen.
Spezifikationen
Specification |
---|
Web Share API |
Browser-Kompatibilität
api.Navigator.share
BCD tables only load in the browser
api.Navigator.canShare
BCD tables only load in the browser