前言
favicon.ico是网站的图标也是网站的头像,简单来说,就是让我们的网站更加好看。
本文主要给大家介绍了关于优雅处理Django中favicon.ico图标的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧
起步
默认情况下,浏览器会访问网站 "/favicon.ico" 这个地址获取网站的图标。如果没有配置的话,Django 会返回一个 404 错误。这对于强迫症的人来说,真的很烦。我们有现有的图标,且按开发规范一般存放 static/ 下。
网上的方法
网上找了大概两种处理方式,但都不够优雅。
方法一:使用重定向
在项目的 urls.py 中添加规则:
1
2
3
4
5
6
7
|
from django.urls import path from django.views.generic.base import RedirectView urlpatterns = [ ... path( 'favicon.ico' , RedirectView.as_view(url = 'static/img/favicon.ico' )), ] |
这种方式我认为是最不好的一种方式,它会让浏览器产生一个新的请求。
方法二:指定图标地址
这种方法就是告诉浏览器,网站图片的正确地址,因此需要在模板中的头部指定:
1
2
3
4
5
6
|
{% 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 规则,返回某个静态文件的:
1
2
3
4
5
6
|
from django.contrib.staticfiles.views import serve urlpatterns = [ ... path( 'favicon.ico' , serve, { 'path' : 'img/favicon.ico' }), ] |
从根本上解决还不反弹,很棒,很好很强大。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:https://www.hongweipeng.com/index.php/archives/1538/