如何优雅地处理Django中的favicon.ico图标详解
前⾔
favicon.ico是⽹站的图标也是⽹站的头像,简单来说,就是让我们的⽹站更加好看。
本⽂主要给⼤家介绍了关于优雅处理Django中favicon.ico图标的相关内容,分享出来供⼤家参考学习,下⾯话不多说了,来⼀起看看详细的介绍吧
起步
默认情况下,浏览器会访问⽹站 "/favicon.ico" 这个地址获取⽹站的图标。如果没有配置的话,Django 会返回⼀个 404 错误。这对于强迫症的⼈来说,真的很烦。我们有现有的图标,且按开发规范⼀般存放 static/ 下。
⽹上的⽅法
⽹上了⼤概两种处理⽅式,但都不够优雅。
⽅法⼀:使⽤重定向
在项⽬的 urls.py 中添加规则:
from django.urls import path
from ic.base import RedirectView
urlpatterns=[
icon图标库...
path('favicon.ico', RedirectView.as_view(url='static/img/favicon.ico')),
]
这种⽅式我认为是最不好的⼀种⽅式,它会让浏览器产⽣⼀个新的请求。
⽅法⼆:指定图标地址
这种⽅法就是告诉浏览器,⽹站图⽚的正确地址,因此需要在模板中的头部指定:
{% load staticfiles %}
<head lang="zh">
<meta charset="UTF-8">
<link rel="shortcut icon" href="{%static " rel="external nofollow" img/favicon.ico" %}" /> <!-- 添加这⾏ -->
<title></title>
</head>
这种⽅法也挺好的。但我还是想从 /favicon.ico 这个地址中解决这个问题。
最优雅的⽅式
django 有⾃⼰的静态⽂件的处理⽅法,那就可以设置 url 规则,返回某个静态⽂件的:
ib.staticfiles.views import serve
urlpatterns = [
...
path('favicon.ico', serve, {'path': 'img/favicon.ico'}),
]
从根本上解决还不反弹,很棒,很好很强⼤。
总结
以上就是这篇⽂章的全部内容了,希望本⽂的内容对⼤家的学习或者⼯作具有⼀定的参考学习价值,如果有疑问⼤家可以留⾔交流,谢谢⼤家对的⽀持。