web-dev-qa-db-ja.com

ウェブサイトのファビコンを動的に変更する

現在ログインしているユーザーに応じてブランド化されたWebアプリケーションがあります。ページのファビコンをプライベートラベルのロゴに変更したいのですが、コードや方法の例が見つかりませんこれをする。誰もこれを成功させたことがありますか?

フォルダーにアイコンが12個あることを示しています。使用するfavicon.icoファイルへの参照は、HTMLページと共に動的に生成されます。考え?

302
SqlRyan

何故なの?

(function() {
    var link = document.querySelector("link[rel*='icon']") || document.createElement('link');
    link.type = 'image/x-icon';
    link.rel = 'shortcut icon';
    link.href = 'http://www.stackoverflow.com/favicon.ico';
    document.getElementsByTagName('head')[0].appendChild(link);
})();

Firefoxはそれでかっこいいはずです。

既存のアイコンを適切に上書きするように編集

339
keparo

Firefox、Opera、およびChromeで動作するコードを次に示します(他のすべての回答とは異なります)。ここに別の IE11で動作するコードのデモ もあります。次の例は、SafariまたはInternet Explorerでは機能しない可能性があります。

/*!
 * Dynamically changing favicons with JavaScript
 * Works in all A-grade browsers except Safari and Internet Explorer
 * Demo: http://mathiasbynens.be/demo/dynamic-favicons
 */

// HTML5™, baby! http://mathiasbynens.be/notes/document-head
document.head = document.head || document.getElementsByTagName('head')[0];

function changeFavicon(src) {
 var link = document.createElement('link'),
     oldLink = document.getElementById('dynamic-favicon');
 link.id = 'dynamic-favicon';
 link.rel = 'shortcut icon';
 link.href = src;
 if (oldLink) {
  document.head.removeChild(oldLink);
 }
 document.head.appendChild(link);
}

その後、次のように使用します。

var btn = document.getElementsByTagName('button')[0];
btn.onclick = function() {
 changeFavicon('http://www.google.com/favicon.ico');
};

Fork away または デモを見る

79
Mathias Bynens

次のHTMLスニペットがある場合:

<link id="favicon" rel="shortcut icon" type="image/png" href="favicon.png" />

たとえば、このリンクのHREF要素を変更することにより、Javascriptを使用してファビコンを変更できます(JQueryを使用している場合):

$("#favicon").attr("href","favicon2.png");

Favicon Defender と同様に、Canvas要素を作成し、HREFをキャンバスのToDataURL()として設定することもできます。

42
fserb

jQueryバージョン:

$("link[rel='shortcut icon']").attr("href", "favicon.ico");

またはさらに良い:

$("link[rel*='icon']").attr("href", "favicon.ico");

Vanilla JSバージョン:

document.querySelector("link[rel='shortcut icon']").href = "favicon.ico";

document.querySelector("link[rel*='icon']").href = "favicon.ico";
32
vorillaz

より現代的なアプローチ:

const changeFavicon = link => {
  let $favicon = document.querySelector('link[rel="icon"]')
  // If a <link rel="icon"> element already exists,
  // change its href to the given link.
  if ($favicon !== null) {
    $favicon.href = link
  // Otherwise, create a new element and append it to <head>.
  } else {
    $favicon = document.createElement("link")
    $favicon.rel = "icon"
    $favicon.href = link
    document.head.appendChild($favicon)
  }
}

その後、次のように使用できます。

changeFavicon("http://www.stackoverflow.com/favicon.ico")
13

ファビコンは次のようなものでheadタグで宣言されます:

<link rel="shortcut icon" type="image/ico" href="favicon.ico">

ビューデータで必要なアイコンの名前を渡すだけで、ヘッドタグにスローできるようになります。

10
Jeff Sheldon

Opera、Firefox、Chromeに動的なファビコンサポートを追加するために使用するコードを次に示します。 IEまたはSafariが動作しませんでした。基本的にChromeは動的ファビコンを許可しますが、ページの場所(またはその中のiframeなど)が変更された場合にのみ、それらを更新します。

var IE = navigator.userAgent.indexOf("MSIE")!=-1
var favicon = {
    change: function(iconURL) {
        if (arguments.length == 2) {
            document.title = optionalDocTitle}
        this.addLink(iconURL, "icon")
        this.addLink(iconURL, "shortcut icon")

        // Google Chrome HACK - whenever an IFrame changes location 
        // (even to about:blank), it updates the favicon for some reason
        // It doesn't work on Safari at all though :-(
        if (!IE) { // Disable the IE "click" sound
            if (!window.__IFrame) {
                __IFrame = document.createElement('iframe')
                var s = __IFrame.style
                s.height = s.width = s.left = s.top = s.border = 0
                s.position = 'absolute'
                s.visibility = 'hidden'
                document.body.appendChild(__IFrame)}
            __IFrame.src = 'about:blank'}},

    addLink: function(iconURL, relValue) {
        var link = document.createElement("link")
        link.type = "image/x-icon"
        link.rel = relValue
        link.href = iconURL
        this.removeLinkIfExists(relValue)
        this.docHead.appendChild(link)},

    removeLinkIfExists: function(relValue) {
        var links = this.docHead.getElementsByTagName("link");
        for (var i=0; i<links.length; i++) {
            var link = links[i]
            if (link.type == "image/x-icon" && link.rel == relValue) {
                this.docHead.removeChild(link)
                return}}}, // Assuming only one match at most.

    docHead: document.getElementsByTagName("head")[0]}

ファビコンを変更するには、上記を使用してfavicon.change("ICON URL")に移動します。

http://softwareas.com/dynamic-favicons 私がこれに基づいたコードの功績)

9
cryo

Gregのアプローチを使用して、favicon.icoのカスタムハンドラーを作成します。

using System;
using System.IO;
using System.Web;

namespace FaviconOverrider
{
    public class IcoHandler : IHttpHandler
    {
    public void ProcessRequest(HttpContext context)
    {
        context.Response.ContentType = "image/x-icon";
        byte[] imageData = imageToByteArray(context.Server.MapPath("/ear.ico"));
        context.Response.BinaryWrite(imageData);
    }

    public bool IsReusable
    {
        get { return true; }
    }

    public byte[] imageToByteArray(string imagePath)
    {
        byte[] imageByteArray;
        using (FileStream fs = new FileStream(imagePath, FileMode.Open, FileAccess.Read))
        {
        imageByteArray = new byte[fs.Length];
        fs.Read(imageByteArray, 0, imageByteArray.Length);
        }

        return imageByteArray;
    }
    }
}

次に、IIS6のWeb構成のhttpHandlersセクションでそのハンドラーを使用するか、IIS7の「ハンドラーマッピング」機能を使用できます。

5
Dan

JQueryを使用するユーザー向けの単一行ソリューションがあります。

$("link[rel*='icon']").prop("href",'https://www.stackoverflow.com/favicon.ico');
3
Pepelegal

IEでこれを機能させる唯一の方法は、*。icoのリクエストを処理するようにWebサーバーを設定して、サーバー側のスクリプト言語(PHP、.NETなど)を呼び出すことです。また、*。icoをセットアップして単一のスクリプトにリダイレクトし、このスクリプトに正しいファビコンファイルを配信させます。同じブラウザで異なるファビコン間を行き来できるようにしたい場合は、キャッシュに関する興味深い問題がまだあると確信しています。

3
Greg

WikiPedia によれば、linkセクションのheadタグを使用して、rel="icon"のパラメーターを使用して、どのファビコンファイルをロードするかを指定できます。

例えば:

 <link rel="icon" type="image/png" href="/path/image.png">

その呼び出し用に動的コンテンツを作成したい場合、Cookieにアクセスしてセッション情報を取得し、適切なコンテンツを提示できると思います。

ファイル形式(IEは.ICO形式のみをサポートし、他のほとんどの人はPNGおよびGIF画像をサポートしていると報告されています)と、おそらくブラウザとプロキシの両方でキャッシュの問題に陥る可能性があります。これは、特にサイトのミニロゴでブックマークをマークするためのファビコンの本来の意図によるものです。

2
staticsan

または、絵文字が必要な場合:)

var canvas = document.createElement("canvas");
canvas.height = 64;
canvas.width = 64;

var ctx = canvas.getContext("2d");
ctx.font = "64px serif";
ctx.fillText("☠️", 0, 64); 

$("link[rel*='icon']").prop("href", canvas.toDataURL());

小道具 https://koddsson.com/posts/emoji-favicon/

2
max4ever

はい、まったく可能です

  • Favicon.icoの後にquerystringを使用します(および他のファイルリンク-以下の回答リンクを参照)
  • サーバーが正しいイメージファイル(「staticルーティングルール、またはdynamicサーバー側コード)。

例えば.

<link rel="shortcut icon" href="/favicon.ico?userId=someUserId">

サーバー側の言語/フレームワークを使用すると、serIdに基づくファイルを簡単に見つけて、そのリクエストへの応答で提供できるはずです。 =。

しかし、ファビコンを適切に行うには(実際にはreally複雑な件名)こちらの回答をご覧ください https://stackoverflow.com/a/45301651/661584

すべての詳細を自分で解決するよりもずっと簡単です

楽しい。

2
MemeDeveloper