Da Bluesky immer beliebter wird, werden immer mehr Tools rund um Bluesky entwickelt. Eine der beliebtesten Anwendungen ist die Postplanung und -automatisierung.
Allerdings bietet die API von Bluesky derzeit keine direkte Möglichkeit, Links mit OpenGraph-Karten zu posten. Dies kann eine Herausforderung für Benutzer sein, die Links mit attraktiven Vorschauen teilen möchten.
In diesem Tutorial zeigen wir Ihnen, wie Sie JavaScript verwenden, um mit einer Einbettungskarte einen Link auf Bluesky zu posten. Diese Methode umgeht die API-Beschränkung, sodass Sie Links effektiver teilen können.
Lasst uns anfangen!
Posten auf Bluesky mithilfe der JavaScript-API
Die Arbeit mit der Bluesky API ist ziemlich einfach. Die Dokumente sind ziemlich gut. Zuerst müssen wir das @atproto/api-Paket von NPM installieren:
npm install @atproto/api
Als nächstes erstellen wir eine Instanz des Bluesky Agent und melden uns mit Ihren Bluesky-Anmeldeinformationen an.
Ich empfehle, ein neues App-Passwort für Ihr Bluesky-Konto zu erstellen, anstatt Ihr Hauptpasswort zu verwenden. Dadurch wird es einfacher, den Zugriff bei Bedarf zu widerrufen und Ihr Hauptkonto zu schützen. Stellen Sie außerdem sicher, dass Sie in Ihrem Projekt die Umgebungsvariablen BLUESKY_USERNAME und BLUESKY_PASSWORD festlegen.
import { AtpAgent } from "@atproto/api" const getBlueskyAgent = async () => { const agent = new AtpAgent({ service: "https://bsky.social", }) await agent.login({ identifier: process.env.BLUESKY_USERNAME!, password: process.env.BLUESKY_PASSWORD!, }) return agent }
Sobald Sie den Agenten haben, können Sie damit auf Bluesky posten, was ziemlich einfach ist.
/** * Send a post to Bluesky * @param text - The text of the post */ export const sendBlueskyPost = async (text: string, url?: string) => { const agent = await getBlueskyAgent() await agent.post({ text }) }
Und da haben Sie es, Sie haben gerade einen Beitrag an Bluesky gesendet. Selbst wenn Sie einen Link in den Text Ihres Beitrags einfügen, wird dieser leider nicht automatisch in einen Ankerlink umgewandelt. Wir werden das in Kürze beheben.
Facettierte Links auf Bluesky automatisch erkennen
Wenn Sie einen Link in Ihren Beitragstext auf Bluesky einfügen, wird dieser nicht automatisch in einen Ankerlink umgewandelt. Stattdessen erscheint es als einfacher Text.
Um dies zu beheben, müssen Sie die Links erkennen und in facettierte Links umwandeln.
Obwohl es manuelle Methoden gibt, um dies zu erreichen, bietet ATProto glücklicherweise eine RichText-Klasse, die Links automatisch erkennen und in facettierte Links umwandeln kann.
import { RichText } from "@atproto/api" /** * Send a post to Bluesky * @param text - The text of the post */ export const sendBlueskyPost = async (text: string) => { const agent = await getBlueskyAgent() const rt = new RichText({ text }) await rt.detectFacets(agent) await agent.post({ text: rt.text, facets: rt.facets, }) }
Das ist großartig, aber wir müssen dem Beitrag noch die Einbettungskarte hinzufügen. Machen wir das als nächstes.
Erstellen einer Einbettungskarte auf Bluesky
Das Einfügen eines Links in Ihren Beitrag ist großartig, aber noch besser ist es, wenn Sie eine Einbettungskarte hinzufügen können.
Um dies zu erreichen, müssen wir die Website-Karteneinbettungsfunktion von Bluesky verwenden. Im Wesentlichen fügen Sie Ihrem Beitrag einen Einbettungsschlüssel hinzu, der mindestens eine URL, einen Titel und eine Beschreibung enthält.
Es gibt mehrere Möglichkeiten, die erforderlichen Daten zu erhalten. Wenn Sie es zum Zeitpunkt der Veröffentlichung wissen, können Sie es einfach fest codieren. Andernfalls können Sie die URL durchsuchen, um Titel, Beschreibung und Bild zu erfassen.
Am einfachsten finde ich es jedoch, die Metatags-API von Dub.co zu verwenden, um die URL-Metadaten abzurufen und daraus dann die Einbettungskarte zu erstellen. Mal sehen, wie das funktioniert.
npm install @atproto/api
Wir haben eine einfache Funktion erstellt, die die URL-Metadaten abruft und die Daten dann in einem klaren Format zurückgibt.
Als nächstes erstellen wir eine Funktion, die die Metadaten verwendet, um das Bild auf Bluesky hochzuladen und dann die Einbettungskarte zu erstellen.
import { AtpAgent } from "@atproto/api" const getBlueskyAgent = async () => { const agent = new AtpAgent({ service: "https://bsky.social", }) await agent.login({ identifier: process.env.BLUESKY_USERNAME!, password: process.env.BLUESKY_PASSWORD!, }) return agent }
Sobald wir die Einbettungskarte haben, können wir sie dem Beitrag hinzufügen.
/** * Send a post to Bluesky * @param text - The text of the post */ export const sendBlueskyPost = async (text: string, url?: string) => { const agent = await getBlueskyAgent() await agent.post({ text }) }
Jetzt haben wir eine Funktion, die einen Beitrag mit einer Einbettungskarte an Bluesky sendet.
Vollständiges Beispiel
Wenn Sie mitgemacht haben, sollten Sie jetzt hoffentlich über einen vollständigen Code verfügen. Wenn nicht, finden Sie hier den vollständigen Code, den Sie kopieren und in Ihr Projekt einfügen können. Es:
- Erstellt einen Bluesky-Agenten
- Ruft die URL-Metadaten ab
- Erstellt eine Einbettungskarte
- Sendet einen Beitrag mit der Einbettungskarte an Bluesky und erkennt automatisch facettierte Links
import { RichText } from "@atproto/api" /** * Send a post to Bluesky * @param text - The text of the post */ export const sendBlueskyPost = async (text: string) => { const agent = await getBlueskyAgent() const rt = new RichText({ text }) await rt.detectFacets(agent) await agent.post({ text: rt.text, facets: rt.facets, }) }
Ich hoffe, dass Sie dieses Tutorial hilfreich fanden und darüber nachdenken, es in Ihren eigenen Projekten zu verwenden.
Viel Spaß beim Posten!
Das obige ist der detaillierte Inhalt vonSo posten Sie mit JavaScript einen Link mit Einbettungskarte auf Bluesky. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Detaillierte Erläuterung der Methode für JavaScript -Zeichenfolge und FAQ In diesem Artikel werden zwei Möglichkeiten untersucht, wie String -Zeichen in JavaScript ersetzt werden: Interner JavaScript -Code und interne HTML für Webseiten. Ersetzen Sie die Zeichenfolge im JavaScript -Code Die direkteste Möglichkeit ist die Verwendung der Ersatz () -Methode: str = str.replace ("find", "ersetzen"); Diese Methode ersetzt nur die erste Übereinstimmung. Um alle Übereinstimmungen zu ersetzen, verwenden Sie einen regulären Ausdruck und fügen Sie das globale Flag G hinzu:: STR = Str.Replace (/fi

Hier sind Sie also bereit, alles über dieses Ding namens Ajax zu lernen. Aber was genau ist das? Der Begriff AJAX bezieht sich auf eine lose Gruppierung von Technologien, mit denen dynamische, interaktive Webinhalte erstellt werden. Der Begriff Ajax, ursprünglich von Jesse J geprägt

In Artikel werden JavaScript -Bibliotheken erstellt, veröffentlicht und aufrechterhalten und konzentriert sich auf Planung, Entwicklung, Testen, Dokumentation und Werbestrategien.

In dem Artikel werden Strategien zur Optimierung der JavaScript -Leistung in Browsern erörtert, wobei der Schwerpunkt auf die Reduzierung der Ausführungszeit und die Minimierung der Auswirkungen auf die Lastgeschwindigkeit der Seite wird.

Bringen Sie Matrix -Filmeffekte auf Ihre Seite! Dies ist ein cooles JQuery -Plugin, das auf dem berühmten Film "The Matrix" basiert. Das Plugin simuliert die klassischen grünen Charakter-Effekte im Film und wählen Sie einfach ein Bild aus, und das Plugin verwandelt es in ein mit numerischer Zeichen gefüllte Bild im Matrix-Stil. Komm und probiere es aus, es ist sehr interessant! Wie es funktioniert Das Plugin lädt das Bild auf die Leinwand und liest die Pixel- und Farbwerte: Data = ctx.getImagedata (x, y, setting.grainize, setting.grainesize) .data Das Plugin liest geschickt den rechteckigen Bereich des Bildes und berechnet JQuery, um die durchschnittliche Farbe jedes Bereichs zu berechnen. Dann verwenden Sie

In dem Artikel werden effektives JavaScript -Debuggen mithilfe von Browser -Entwickler -Tools, der Schwerpunkt auf dem Festlegen von Haltepunkten, der Konsole und der Analyse der Leistung erörtert.

In diesem Artikel werden Sie mit der JQuery -Bibliothek ein einfaches Bildkarousel erstellen. Wir werden die BXSLIDER -Bibliothek verwenden, die auf JQuery basiert und viele Konfigurationsoptionen zum Einrichten des Karussells bietet. Heutzutage ist Picture Carousel zu einem Muss auf der Website geworden - ein Bild ist besser als tausend Wörter! Nachdem Sie sich entschieden haben, das Bild -Karussell zu verwenden, ist die nächste Frage, wie Sie es erstellen. Zunächst müssen Sie hochwertige, hochauflösende Bilder sammeln. Als nächstes müssen Sie ein Bildkarousel mit HTML und einem JavaScript -Code erstellen. Es gibt viele Bibliotheken im Web, die Ihnen helfen können, Karussell auf unterschiedliche Weise zu erstellen. Wir werden die Open -Source -BXSLIDER -Bibliothek verwenden. Die BXSLIDER -Bibliothek unterstützt reaktionsschnelles Design, sodass das mit dieser Bibliothek gebaute Karussell an alle angepasst werden kann

Wichtige Punkte erweiterte strukturierte Tagging mit JavaScript können die Zugänglichkeit und Wartbarkeit von Webseiteninhalten erheblich verbessern und gleichzeitig die Dateigröße reduzieren. JavaScript kann effektiv verwendet werden, um HTML -Elementen dynamisch Funktionen hinzuzufügen, z. Durch das Integrieren von JavaScript in strukturierte Tags können Sie dynamische Benutzeroberflächen erstellen, z. B. Tabletten, für die keine Seiten -Aktualisierung erforderlich ist. Es ist entscheidend sicherzustellen, dass JavaScript -Verbesserungen die grundlegende Funktionalität von Webseiten nicht behindern. Erweiterte JavaScript -Technologie kann verwendet werden (


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

EditPlus chinesische Crack-Version
Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

VSCode Windows 64-Bit-Download
Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung