I think it's strange that a route change would trigger a request for the favicon.
Is this intended or what is going on here?
I think it's strange that a route change would trigger a request for the favicon.
Is this intended or what is going on here?
I had the same problem and I believe the problem started with the Chrome 49.0.2623.87. I hope it is going to be fixed in the coming updates. For now, I am using the script below, which can be found here.
var favIcon = "favicon.ico";
var docHead = document.getElementsByTagName('head')[0];
var newLink = document.createElement('link');
newLink.rel = 'shortcut icon';
newLink.href = 'data:image/png;base64,'+favIcon;
docHead.appendChild(newLink);
It will not stop the favicon requests, so for a short period of time you still will see the default favicon from chrome, but I believe there is not much to be done about that.
I found a solution on Github. Quoting @Doeke:
Try reordering the favicon link tags. For me, putting the 16x16 link before 32x32 fixed this issue. As for why this works... I have no idea.
For me, it meant putting the only favicon <link>
on my page right at the top of <head>
, after <meta charset>
.
Try to serve favicon.ico
from your server or add route for that. I was experienced such error when using express catch-all app.get('*')
method which redirected all requests to index.html
(even for favicon)
Change the
<link>
tag as mentioned below inStep 6
, or follow the comments.
Embedding the icon
inline as a Data URL
will do the magic!
What is a Data URL?
Data URLs allow content creators to embed small files inline in documents.
Convert favicon image to Data URI from this link: Converter
Upload the .ico file from the public folder.
Next, select output format as: Data URI -- data:content/type;base64
Next change the <link>
tag's href with the generated output!
Replace this line(
<link rel="icon" href="%PUBLIC_URL%/favicon.ico" />
) inpublic > index.html
.
TO this line ↓↓
<link
rel="icon"
href=""
/>
Now whenever this href
is parsed, the DATA URL is loaded, instead of the .ico file. Hence, no new requests will be sent to the server as the data is embedded inline!
Change the favicon request by the following line of code in your index.html page
<link rel="icon" href="data:image/vnd.microsoft.icon;base64,<data>">
here, <data>
is the base64 data of your favicon.
refer https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs
This trick stops the user’s browser from sending an automatic HTTP request for the favicon.
For me, while using Next 13, replacing
<head>
with <Head>
(note case) seems to fix the issue.