Wie wird das Favicon / Symbol festgelegt, wenn das Lesezeichen in die Symbolleiste gezogen wird?

108

Ich habe mir ein Lesezeichen gemacht und es funktioniert einwandfrei, aber wenn es einer Symbolleiste in Opera oder Firefox hinzugefügt wird, wird nur das Standard-Lesezeichensymbol für den Browser (ein Globus bzw. ein Stern) verwendet. Meine Site hat ein Favicon, und das Fenster, die Registerkarte und sogar das Lesezeichen [Site] verwenden das von mir angegebene Favicon. Nur nicht mein Lesezeichen.

Wie kann ich meine Site oder mein Lesezeichen so codieren, dass das Lesezeichen auch das Favicon erhält?

Mir sind verschiedene manuelle Hackery-Techniken bekannt, mit denen Benutzer das Favicon nachträglich festlegen können, aber dies sind unerwünschte Lösungen.

Pistos
quelle
Beispiel: Durch Ziehen des Lesezeichens in Opera erhält das Lesezeichen ein Diigo-Symbol: diigo.com/tools/diigolet
Pistos
Der, auf den Sie verlinken, macht das in Firefox nicht für mich.
Benlumley
Ja, auch nicht im IE. Aber es macht es in Opera. :)
Pistos
Entschuldigung, ich habe gerade Opear 9.6 ausprobiert und es funktioniert auch nicht in Opera.
Guss
1
Hier gibt es einen Lösungsvorschlag: wiki.whatwg.org/wiki/Link_Icons
lapo

Antworten:

23

Ein Lesezeichen verwendet das javascript://Schema und verfügt daher nicht über eine Domäne, aus der ein Favicon geladen werden kann.

Derzeit können Sie also kein Favicon für ein Lesezeichen bereitstellen. Stellen Sie sich das so vor: Erinnern Sie sich an die ganze Javascript-Sandbox - wo Javascript möglicherweise nicht auf etwas außerhalb der Domäne der Webseite zugreift, auf der es ausgeführt wird? Nun, ein Lesezeichen, das für die aktuelle Seite, die Sie gerade ansehen, an eine beliebige Domain gebunden sein muss, kann nicht auch an ein Favicon auf Ihrer eigenen Website gebunden werden.

Update: Nach der Antwort von Hans Schmucker besteht die Möglichkeit, ein Lesezeichen zu erstellen, das beim Laden durch den Browser in das Lesezeichenmenü ein HTML-Dokument mit einem Favicon generiert. Die Argumentation scheint zu funktionieren, aber ich habe so etwas noch nicht in Aktion gesehen und meine Tests sind negativ ausgefallen.

Guss
quelle
17

So können Sie das machen:

  1. Ziehen Sie Ihr Lesezeichen in die Lesezeichenleiste.
  2. Erstellen Sie daneben ein Lesezeichen für eine Site, deren Favicon Sie für Ihr Lesezeichen verwenden möchten.
  3. Öffnen Sie den Lesezeichen-Manager, klicken Sie auf die Dropdown-Liste Organisieren und wählen Sie Exportieren. Speichern Sie Ihre Lesezeichen als HTML-Datei.
  4. Öffnen Sie diese HTML-Datei im Texteditor.
  5. Suchen Sie das Lesezeichen, das Sie gerade erstellt haben, beispielsweise das Google Mail-Lesezeichen. Sie sollten einen HTML-Code dafür haben, der folgendermaßen aussieht:

<DT><A HREF="http://mail.google.com/mail/u/0/#inbox" ICON="">Gmail</A>

  1. Kopieren Sie das gesamte ICON-Tag
  2. Suchen Sie in derselben Datei das von Ihnen erstellte Lesezeichen und fügen Sie das von Ihnen kopierte ICON-Tag in Ihr Lesezeichen- Tag ein:

<DT><A HREF="javascript:(function(){... bookmarklet JS code...})();" ICON="">MyBookmarklet</A>

  1. Speichern Sie diese Datei
  2. Kehren Sie zum Chrom Bookmarks Manager zurück, klicken Sie erneut auf Organisieren und wählen Sie Importieren
  3. Importieren Sie die gerade bearbeitete HTML-Datei. Ihr Lesezeichen verfügt jetzt über ein Favicon .

Grundsätzlich besteht das Verfahren darin, das ICON-Attribut eines Lesezeichen- Tags abzurufen und in das Lesezeichen- Tag einzufügen

Geben Sie hier die Bildbeschreibung ein

monstro
quelle
1
(Dies ist eine sehr alte Frage, aber ...) Ich suchte nach einer Lösung, für die überhaupt keine Endbenutzeraktion erforderlich war (außer das Hinzufügen des Lesezeichens zur Symbolleiste). dh was kann ein Websitebesitzer tun, um das Symbol anzugeben.
Pistos
1
Für mich ist das die beste Antwort. Es funktioniert und es wird umfassend erklärt. Vielen Dank.
Tsuma534
13

Das ist nicht ganz richtig: Ein Lesezeichen hat keine Domain, aber einen Speicherort (das ist das Lesezeichen selbst), und Sie können diesem ein Symbol zuweisen. Danach kommt es darauf an, wie der Browser Symbole speichert (Firefox speichert das Symbol eines Lesezeichens dauerhaft, Sie haben möglicherweise nicht so viel Glück mit anderen Browsern).

PS Security spielt nicht einmal hinein, Symbole können von überall her kommen. Es gibt keine Einschränkung.

Siehe http://www.tapper-ware.net/blog/?p=97

Hans Schmucker
quelle
3
Während die Argumentation so klingt, als ob sie funktionieren könnte, generieren die Beispiele in dem Blog, auf das Sie verlinkt haben, entweder nur ein Dokument mit einem Symbol, das Firefox möglicherweise für das Lesezeichen anzeigt oder nicht, oder es handelt sich tatsächlich um Lesezeichen, die Javascript auf beliebigen Seiten ausführen - aber nicht beide (getestet auf Firefox 7). Ich bin immer noch nicht von dieser Arbeit überzeugt.
Guss
13

Nachdem ich die Website von tapper [ware] und Restafarian gelesen habe, ist hier die einfachste Lösung, die ich finden könnte:

<a href="javascript:

var title = window.location.href;

if (title.indexOf('http://yourwebsite/bookmarklet/') == 0) {
    '<head><link rel=\'shortcut icon\' href=\'favicon.ico\'></head>Bookmarklet';
} else {
    (function(){document.body.appendChild(document.createElement('script')).src='http://yourwebsite/bookmarklet.js';})();
}">Click Me!</a>

Funktioniert hervorragend in Chrome und FF, aber FF4 ist der einzige Browser, der das Symbol in der Lesezeichenleiste speichert. So sieht es aus: http://cl.ly/5WNR

Brian McAllister
quelle
Ich versuche, mehr über Lesezeichen zu erfahren. Können Sie Neulingen den Code ein wenig erklären? Vielen Dank
Andrew Mackenzie
Sicher. Wenn Sie darauf klicken, wird die URL der aktuellen Seite überprüft. Wenn Sie sich auf der Seite befinden, auf der Ihr Lesezeichen "gehostet" ist (Zeile 4), wird ein Linkelement auf die Seite geschrieben, die auf das gewünschte Favicon verweist. Ihr Browser wird dies sehen und das Favicon herunterladen. Der Browser speichert dies zwischen und verwendet es als Symbol in Ihrer Lesezeichenleiste. Wenn Sie sich auf einer anderen Seite befinden, wird nur das getan, was Ihr Lesezeichen tun soll.
Brian McAllister
5
Ich verstehe das nicht. Wenn Sie ein Lesezeichen in Ihre Favoritenleiste ziehen (wie beim Delicious-Lesezeichen hier ), wie wird dieser Code ausgeführt? Ich verstehe nicht, warum auf das Lesezeichen geklickt wird (und der Code ausgeführt wird), bis es in der Favoritenleiste gespeichert wurde, dh nachdem sich der Browser auf sein Symbol festgelegt hat.
Dumbledad
6

Hier ist eine schöne Technik, die fast macht, was Sie wollen

Funktioniert hervorragend auf meinem Mac✅, aber ich konnte es unter Windows 7⃣ nicht zum Laufen bringen

Verwenden Sie "Emoji" 🈳. Es sind Unicode-Zeichen, die zufällig auch wie bunte Symbole aussehen. Sie können nur aus einer vordefinierten Liste von Bildern auswählen, aber eigentlich ist es nicht schlecht, wenn Sie dem Benutzer nur etwas zum Anschauen geben möchten, um ihn daran zu erinnern, was das Lesezeichen tut.

Zum Beispiel mache ich ein Lesezeichen "Sicherheitsschlüssel". Also benutze ich 🔑 in meinem Lesezeichennamen! 😃😊

Im Grunde sehen Sie das Bild in der Lesezeichenleiste

Verwenden Sie diese Website, um ein Emoji zu finden, das für Ihr Lesezeichen geeignet ist: http://emojipedia.org/symbols/

Das Ö
quelle
1
Ich bekomme nur eine ganze Reihe von "Schrift hat keine Glyphe für diesen Codepunkt" -Markierungen. Angesichts der Tatsache, dass ich Firefox unter Linux verwende, bedeutet dies, dass das Fallback-Verhalten sie nicht einmal in einer Schriftart auf dem System finden konnte. Habe ich Recht, wenn ich vermute, dass dies die Mac-spezifischen Emoji-Glyphen sind, die Blogger Webdesignern empfohlen haben, zu vermeiden?
Ssokolow
Ja. Wenn Sie jedoch wissen, dass Ihr Client auf einem Computer ausgeführt wird, auf dem Emoji angezeigt werden kann, ist es dann so schlecht, diese anzuzeigen? Für meinen persönlichen Gebrauch kann der Benutzer entscheiden, ob er Emoji ausgeben möchte oder nicht. Wenn nicht, gebe ich keine aus, sie erhalten nur einfachen Text.
Theo
Abgesehen davon, dass dies eine Lösung ist, die über unzählige Fehler im Webdesigner stolpern könnte, würde ich nicht den schlechten Eindruck riskieren, den ich machen könnte, wenn (nicht wenn) jemand unvermeidlich etwas lädt, das ich auf einem Nicht-Mac-System aufbaue.
ssokolow
Dies teilweise aus praktischen Gründen und teilweise aus Unterhaltungsgründen zu verbessern. Emojis sind die Antwort auf alle Probleme des Lebens!
Sridhar Sarnobat
Tipp: Verwenden Sie diese Website, um die benötigten Emojis zu kopieren und einzufügen : emojipedia.org/upwards-black-arrow .
Sridhar Sarnobat
4

Auf Vorschlag von Wizek können Sie Ihren Code in eine Daten- URL einfügen.

data:text/html;charset=utf-8,
<html>
<link rel="shortcut icon" href="https://stackoverflow.com/favicon.ico">
<script type="text/javascript">
    alert('It works!')
</script></html>

Und speichern Sie das alles als Lesezeichen. ( Probieren Sie es aus! Ziehen Sie den Code in Ihre Registerkartenleiste.)

Leider funktioniert es nur in bestimmten Fällen (mehr unten).

Wie es funktioniert:

(Zumindest in Chrome) Es ähnelt einem Lesezeichen, das das Format verwendet, das javascript: "<html>...your html code here, including a javascript tag that will run when loaded...</html>"andere Lösungen vorgeschlagen haben. In diesem Fall wird der HTML-Code der Seite, auf der Sie sich befinden , durch den HTML-Code aus dem Lesezeichen ersetzt, der Speicherort bleibt jedoch unverändert und das Lesezeichen selbst hat immer noch keinen Speicherort, sodass Chrome kein Favicon dafür speichern kann.

Im Gegensatz dazu gehen wir mit einem Daten-Uri-Lesezeichen auf die andere Seite , es hat einen eigenen Speicherort und der Browser kann ein Favicon dafür speichern. Stellen Sie sich das als "Hosten einer Website in Ihrem Browser" vor, auf die Sie auf anderen Computern zugreifen können, wenn Sie Ihre Lesezeichen synchronisieren. Sie können anstelle einer URL auch ein base64-Image für das Favicon verwenden, wenn Sie alles lokal halten möchten.

Es hat Einschränkungen.

  • Wenn Sie darauf klicken, verlässt es die aktuelle Seite und lädt die Seite in die Daten . Daher können Sie es nicht für Bookmarlets verwenden, die mit der aktuellen Seite interagieren, sondern nur für Code, den Sie auf einer anderen Seite ausführen können.

  • Verwenden Sie // nicht für Kommentare. Da alles in einer Zeile gespeichert wird, wickeln Sie sie in / ** / ein und vergessen Sie Ihre Semikolons nicht

  • In FF wurde das Favicon gespeichert, aber ich konnte es nicht so einstellen, dass Popup-Fenster immer geöffnet werden, wenn ich window.open () verwenden möchte, da ich damit kein Standardverhalten für Daten-URLs speichern kann


Als Beispiel:

Mit dieser Technik habe ich ein kleines Lesezeichen mit Symbolgenerator erstellt. Sie können diesen Code in Ihre URL-Leiste ziehen (oder als Lesezeichen speichern), um ihn zu verwenden. Es ist eine einfache Seite mit einem Eingabebereich für Code und für ein Symbol, und anschließend wird ein Lesezeichen mit dem Symbol erstellt

data:text/html;charset=utf-8,<html><head>
    <title>Bookmarklet With Icon Generator</title>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" ></script>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" >
    <link rel="shortcut icon" href="https://www.freefavicon.com/freefavicons/objects/plain-thumbs-up-152-237293.png">
</head>
<body>
    <div class="container">
        <div class="page-header">
            <h2>Write your javascript  and specify a favicon, then drag the button to your bookmarks bar</div>
                </h2>
        <a id="bookmarkbutton" href='' ondragend='this.click()' draggable="true" class="btn btn-primary btn-lg" role="button"> 
            Drag me to your bookmarks bar! </a><br /><br />
        <div> 
            <label for="fav_href">Favicon:</label>
            <input id="fav_href" value='https://stackoverflow.com/favicon.ico' style='width:100%'></input> </div><br />
        <div>
            <label for='ta'>Write your JavaScript below</label>
            <textarea id="ta" style="width:100%;height:50%">
setTimeout(()=>{            &%2313
    alert('hello world');   /*Use this format for comments, use %2523 instead of hash (number sign)*/ &%2313
    window.history.back();  &%2313
},200);
            </textarea></div>
  </div>
    <script type = "text/javascript">
        fav_href.onchange = ta.onchange = function(){
            bookmarkbutton.href = 'data:text/html;charset=utf-8,<html><head>'+
                '<link rel="shortcut icon" href="'+ fav_href.value +'">'+
                '<script type="text/javascript"> '+ ta.value +'<\/script>';
            };
        ta.onchange();
    </script>
</body>

Ein weiteres Beispiel: Lesezeichen zum Öffnen des Facebook Messenger in einem eigenen kleinen Fenster (funktioniert möglicherweise nicht, wenn Ihr Browser standardmäßig Popups blockiert)

data:text/html;charset=utf-8,
<html>
    <link rel="shortcut icon" href="https://facebook.com/images/messengerdotcom/favicon/favicon.ico">
    <script type="text/javascript">
        url = 'https://www.messenger.com/';
        w = 740; h = 700;
        x = parseInt( screen.availWidth/2 - w/2 );
        y = parseInt( screen.availHeight/2 - h/2 );
        nw = window.open(url,'', 'width='+ w +',height='+ h +',top='+ y +',left='+ x);
        nw.focus();
        setTimeout(()=>{ 
          window.history.back();
          window.close();  
        },200);
    </script>

Weitere Chrome-Problemumgehungen zum Abrufen von Lesezeichen-Symbolen:

  • Exportieren Sie die Lesezeichenleiste, bearbeiten Sie sie und importieren Sie sie erneut, wie in dieser Antwort beschrieben. Https://superuser.com/questions/212722/how-can-i-add-a-favicon-to-a-bookmarklet-in- Google Chrome

  • Das Lesezeichen in eine Erweiterung verwandeln. Es wird kein Lesezeichen mehr sein, aber es wird dieselbe Funktion haben. Hier ist eine einfache Website, die dies für Sie erledigt: http://sandbox.self.li/bookmarklet-to-extension/. Ändern Sie dann einfach die Symboldatei in die gewünschte Datei. Der Nachteil dabei ist, dass Erweiterungen RAM verbrauchen (etwa 10 MB für einfache?). Wenn Sie viel und wenig RAM haben, ist dies möglicherweise nicht die Lösung für Sie. Außerdem haben Sie keinen Text wie in einem Lesezeichen, sondern nur das Symbol.

aljgom
quelle
1
Dies funktioniert nur für Chrome und Safari. Leider nicht Mozilla. Die Absicht eines Lesezeichens ist es, Cross-Browser, IMO, zu sein.
Sijpkes
Dies ist wie das einzige, was funktioniert hat. Heilige Kuh, vielen Dank.
Alex Beals
3

Es ist möglich, Favicon mit Javascript und Canvas zuzuweisen und zu modifizieren (siehe das erstaunliche Favicon-Spiel Defender of the Favicon ). Der Quellcode des Spiels hilft Ihnen dabei (er basiert im Wesentlichen auf der Verwendung der Funktion toDataUrl () auf der Leinwand, wie in Zeile 554 der Quelle gezeigt).

// set favicon
if( !stupidBrowser && useIcon )
{
     var    icon=$('favicon');
     (newIcon = icon.cloneNode(true)).setAttribute('href',ctx.canvas.toDataURL());
     icon.parentNode.replaceChild(newIcon,icon);
}

Was passiert, wenn ein Bookmarlet, das das Favicon auf diese Weise einstellt, angeklickt oder gespeichert wird? Ich weiß es nicht, aber es könnte schön sein, es zu versuchen. Browser kann es speichern?

Arnaud Rinquin
quelle
1
(In Chrome getestet) Keine Lösung. Wenn Sie ein Favicon mit einem Bookmarlet ändern, befinden Sie sich immer noch am selben Ort. Der Browser ändert möglicherweise das Symbol eines Lesezeichens der aktuellen Seite, weist dem Lesezeichen jedoch kein Lesezeichen zu.
Aljgom
1

Ich denke, dass ein möglicher Weg darin besteht, Unicode-Zeichen im Lesezeichenanker wie Ihr Symbol zu verwenden:

http://unicode-table.com/de/#cyrillic

Wenn Sie alle möglichen Symbole durchsuchen, finden Sie möglicherweise das Zeichen, das dem gewünschten Symbol ähnlicher ist

stefcud
quelle
1

Dies ist also noch keine vollständige Lösung, kann aber ein Schritt in eine Arbeitsrichtung sein.

data:data:Zu meiner Überraschung funktioniert die Codierung eines Symbols in einem -uri-codierten HTML-Code.

data:text/html;charset=utf-8, <title>Separator Tab</title><link rel="shortcut icon" href="" /> Separator Tab

Da dies ist <html>, können wir rennen<script type="javascript"> dort hineinlaufen.

Für einige Lesezeichen ist dies möglicherweise bereits mehr als ausreichend. Für andere, die die aktuelle Seite ändern oder zumindest einige Informationen erhalten möchten, bevor sie einen neuen Tab öffnen, ist das noch ein Pech. Ich werde diese Antwort aktualisieren, wenn ich einen Weg finde, dies zu tun.

Wizek
quelle