我只想把favicon。ico放到我的staticfiles目录中,然后让它显示在我的应用程序中。
我怎样才能做到呢?
我已经把favicon.ico文件放在我的staticfiles目录中,但它没有显示,我在日志中看到了这一点:
127.0.0.1 - - [21/Feb/2014 10:10:53] "GET /favicon.ico HTTP/1.1" 404 -
如果我去http://localhost:8000/static/favicon.ico,我可以看到图标。
我只想把favicon。ico放到我的staticfiles目录中,然后让它显示在我的应用程序中。
我怎样才能做到呢?
我已经把favicon.ico文件放在我的staticfiles目录中,但它没有显示,我在日志中看到了这一点:
127.0.0.1 - - [21/Feb/2014 10:10:53] "GET /favicon.ico HTTP/1.1" 404 -
如果我去http://localhost:8000/static/favicon.ico,我可以看到图标。
当前回答
最佳实践:
与你所想的相反,favicon可以是任何大小和任何图像类型。点击这个链接了解详情。
不给你的图标添加链接会降低页面加载速度。
在django项目中,假设你的favicon的路径是:
myapp/static/icons/favicon.png
在你的django模板中(最好是在基本模板中),添加这一行到页面的头部:
<link rel="shortcut icon" href="{% static 'icons/favicon.png' %}">
注意:
我们假设,静态设置在settings.py中配置得很好。
其他回答
如果你有一个基本或头部模板,包括在任何地方,为什么不包括favicon与基本HTML?
<link rel="shortcut icon" type="image/png" href="{% static 'favicon.ico' %}"/>
有时重新启动服务器会有所帮助。
停止服务器,然后重新运行命令:python manage.py runserver 现在应该加载CSS文件了。
通用解决方案
你可以像在其他框架中一样在Django中显示favicon:只需要使用纯HTML。
将以下代码添加到HTML模板的头部。 如果favicon在整个应用程序中是相同的,最好是到您的基本HTML模板。
<link rel="shortcut icon" href="{% static 'favicon/favicon.png' %}"/>
前面的代码假设:
在静态文件夹中有一个名为“favicon”的文件夹 favicon文件名为favicon。png 您已经正确地设置了设置变量STATIC_URL
你可以在维基百科https://en.wikipedia.org/wiki/Favicon的这篇文章中找到关于文件格式支持和如何使用favicons的有用信息。 我可以推荐使用。png格式的浏览器兼容性。
编辑: 正如一条评论所言, “不要忘记在模板文件顶部添加{% load staticfiles %} !”
在你的settings.py中添加一个根目录staticfiles:
STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static')
]
创建/静态/图片/ ico。位于
添加图标到你的模板(base.html):
{% load static %}
<link rel="shortcut icon" type="image/png" href="{% static 'images/favicon.ico' %}"/>
并在urls.py中创建一个url重定向,因为浏览器会在/favicon.ico中查找favicon
from django.contrib.staticfiles.storage import staticfiles_storage
from django.views.generic.base import RedirectView
urlpatterns = [
...
path('favicon.ico', RedirectView.as_view(url=staticfiles_storage.url('images/favicon.ico')))
]
一个轻量级的技巧是在你的urls.py文件中做一个重定向,例如添加一个这样的视图:
from django.views.generic.base import RedirectView
favicon_view = RedirectView.as_view(url='/static/favicon.ico', permanent=True)
urlpatterns = [
...
re_path(r'^favicon\.ico$', favicon_view),
...
]
当你真的没有其他静态内容要托管时,这是一个让favicons工作的简单技巧。