Um die Privatsphäre ihrer Besucher gegenüber den Social-Media-Netzwerken zu bewahren, können Webseiten-Betreiber mit dem Projekt Shariff eigene Teilen-Buttons integrieren.
Der Code der offiziellen Buttons von Facebook, Google+ und Twitter überträgt von jedem Besucher kennzeichnende Daten an die Social-Media-Netzwerke. Shariff erzeugt hingegen Share-Buttons, die mit einem Klick teilen, die Anzahl der Likes, Tweets und Plus-Ones für die aktuelle Seite anzeigen und trotzdem keine unnötigen Daten übertragen.
Shariff (/ˈʃɛɹɪf/)
ist ein Open-Source Projekt von c't und heise online.
Shariff besteht aus zwei Teilen. Der erste Teil ist eine einfache JavaScript-Bibliothek einschließlich Vektor-Icons und CSS zur Formatierung der Knöpfe. Der zweite ist die optionale, server-seitige Komponente (derzeit für PHP, Perl oder NodeJS). Mit dem Shariff-Backend auf dem eigenen Server muss der Browser des Besuchers zur Darstellung der Share-Counts keine Verbindung zu Facebook, Twitter oder Google+ aufbauen. Daten werden erst dann zum Social-Media-Netzwerk übertragen, wenn der Besucher den Inhalt tatsächlich teilen möchte.
- Das aktuellste Shariff-Release herunterladen
- CSS im
<head>
einbinden:build/shariff.complete.css
enthält alle Abhängigkeitenbuild/shariff.min.css
verwenden, wenn Font Awesome bereits in Ihrer Seite geladen wird
- JavaScript unmittelbar vor
</body>
einbinden:build/shariff.complete.js
enthält alle Abhängigkeitenbuild/shariff.min.js
verwenden, wenn jQuery bereits in der Seite vorhanden ist
- Beliebig viele
<div class="shariff">
Elemente einfügen - Mit den unten beschriebenen
data
-Attributen Aussehen und Funktion konfigurieren
Die Share-Counts in den Buttons benötigen ein Backend auf ihrem Server.
Code-Beispiel:
<!DOCTYPE html>
<html>
<head>
<link href="/path/to/shariff.complete.css" rel="stylesheet">
</head>
<body>
<h1>My article</h1>
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
<h2>Einfache Buttons:</h2>
<div class="shariff"></div>
<h2>Fortgeschrittene Optionen:</h2>
<div class="shariff" data-backend-url="/path/to/backend" data-url="http://www.example.com/my-article.html" data-theme="grey" data-orientation="vertical"></div>
<!-- vor dem schließenden </body>-Tag -->
<script src="/path/to/shariff.complete.js"></script>
</body>
</html>
Shariff ist auch als Node-Paket verfügbar und kann mit npm
in ein Projekt eingebunden werden:
$ cd my-project
$ npm install shariff --save
Dann kann Shariff im eigenen Skript initialisiert und an DOM-Elemente gebunden werden:
// my-app.js
var Shariff = require('shariff');
var $ = require('jquery');
var buttonsContainer = $('.some-selector');
new Shariff(buttonsContainer, {
orientation: 'vertical'
});
Nach dem Download von Shariff mit npm install
die Abhängigkeiten installieren. Anschließend kann mit grunt demo
ein lokaler Webserver gestartet werden, der eine Seite mit verschiedenen Konfigurations-Beispielen bereitstellt:
$ git clone https://github.com/heiseonline/shariff.git
$ cd shariff
$ npm install
$ grunt demo
Für den Aufruf von grunt demo
muss Grunt CLI installiert sein. Die Beispielseite verwendet shariff-backend-node
, um die Share-Counts für die Buttons bereitzustellen.
Attribut | Beschreibung | Default |
---|---|---|
data-backend-url |
Pfad zum Shariff-Backend. Der Wert null deaktiviert die Anzeige von Share-Counts. |
null |
data-lang |
Lokalisierung auswählen. Verfügbar: de , en , es |
de |
data-orientation |
Anordnung der Buttons. Verfügbar: horizontal , vertical |
horizontal |
data-referrer-track |
Wenn angegeben, wird dieser String an die geteilte URL angehängt. Mit null deaktivieren. |
null |
data-services |
Liste der Services, die verwendet werden sollen. Für die Verwendung im data -Attribut muss die Angabe Entity-enkodiert werden. Die Reihenfolge wird berücksichtigt. Beispiel: data-services="["facebook","googleplus"]" Verfügbare Dienste: twitter , facebook , googleplus , mail , info |
Twitter, Facebook, Google+ |
data-theme |
Farbschema auswählen. Verfügbar: standard , grey und white . |
standard |
data-url |
URL, die geteilt werden soll. | Wenn data-url nicht gesetzt ist, wird link[rel="canonical"] , meta[property="og:url"] oder location.href verwendet. |
Wenn in den Shariff-Buttons die Share-Counts angezeigt werden sollen, wird eines der folgenden Backends benötigt:
Drittanbieter-Backends:
Die URL, unter der das Backend erreichbar ist, muss im data
-Attribut data-backend-url
angegeben werden. Ein Backend unter der URL http://example.com/my-shariff-backend/
wird in data-backend-url
so angegeben: /my-shariff-backend/
. Den Rest erledigt das Skript.