自定义Django默认的sitemap站点地图样式


Posted in Python onMarch 04, 2020

Django 中自带了 sitemap框架,用来生成 xml 文件

Sitemap(站点地图)是通知搜索引擎页面的地址,页面的重要性,帮助站点得到比较好的收录。 白话文就是:一个写了你网站的所有url的xml文件,告诉搜索引擎,请及时收录我的这些地址。

sitemap 很重要,可以用来通知搜索引擎页面的地址,页面的重要性,帮助站点得到比较好的收录。

一、站点地图sitemap

一般在Web网站开发完成之际,如果对搜索引擎优化(SEO)有一定的要求,我们都会为网站添加一个站点地图sitemap,配合robot.txt的使用,以汇总和索引网站上所有允许被搜索引擎搜索、采集和索引的网页,这样搜索引擎可以根据站点地图快速地爬取到一个网站上的所有希望被收录的网址。

在Django框架中,有一个自带且基本完整的sitemap框架供我们使用。通过Django提供的sitemap,我们可以很快实现是个站点地图的功能。

二、使用Django的sitemap功能

Django自带的sitemap使用起来非常简单,总结起来就是3步。下面,我们以MrDoc中的使用为例。

第一步,新建一个在应用文件夹下新建一个名为sitemap.py的文件(在MrDoc中的路径为/MrDoc/app_doc/sitemap.py),根据实际站点的需求,我们准备将首页、公开的文集和已发布的文档,放到sitemap中,所以我们要写实例化几个Sitemap类,先来引入它:

# MrDoc Sitemap.py
from django.contrib.sitemaps import Sitemap
from django.urls import reverse
from app_doc.models import Doc,Project

定义一个继承自SiteMap的类,用来生成首页的sitemap:

自定义Django默认的sitemap站点地图样式

接着定义一个文档的sitemap:

# 文档地图
class DocSitemap(Sitemap):
 changefreq = "daily"
 priority = 0.8

 def __init__(self,pro):
  self.pro = pro

 def items(self):
  return Doc.objects.filter(status=1,top_doc=self.pro)

 def lastmod(self,obj):
  return obj.modify_time

文集的sitemap,我们通过调用文档的sitemap来生成:

自定义Django默认的sitemap站点地图样式

在sitemap.py文件中的操作就完成了,我们移步到Django项目的顶级URL路由文件urls.py中(在MrDoc中的路径为/MrDoc/MrDoc/urls.py),进行第二步。

引入相关的模块:

from django.contrib.sitemaps import views
from app_doc.sitemaps import all_sitemaps as sitemaps

然后在urlpatterns中添加两个URL的匹配路径:

path('sitemap.xml', views.index, {'sitemaps': sitemaps},name='sitemap',), # 站点地图索引
path('sitemap-<section>.xml', views.sitemap, {'sitemaps': sitemaps}, # 站点地图
  name='django.contrib.sitemaps.views.sitemap')

最后一步,我们在setting.py文件中(在MrDoc中的路径为/MrDoc/MrDoc/settings.py)的应用列表INSTALLED_APPS中将sitemap的功能应用添加进去:

自定义Django默认的sitemap站点地图样式

这样,为Django创建的网站添加sitemap站点地图功能就已经完成了。我们运行服务,访问127.0.0.1/sitemap.xml就可以看到站点地图:

自定义Django默认的sitemap站点地图样式

这就是Django自带的sitemap的样子了。

站点地图是出来了,但是和我们平常在一些网站上看到了似乎不太一样,不仅不能点击上面的链接,样式也是很简单的XML结构树。而州的先生博客(https://zmister.com)网站上的站点地图就要美观好看得多:

自定义Django默认的sitemap站点地图样式

如果把Django自带的sitemap站点地图美化一下呢?我们可以借助Django提供了自定义sitemap模板功能。

三、自定义sitemap模板

在Django中,sitemap的样式存在于\django\contrib\sitemaps\templates\文件夹下,一共有两个XML模板文件:

  • sitemap.xml
  • sitemap-index.xml

我们需要做的就是新建两个xml文件,在上述两个文件的基础之上,引入XML的样式文件,让XML样式文件对XML文件进行渲染,以实现美化sitemap站点地图的功能。

我们首先从州的先生博客(https://zmister.com)上把站点地图的样式文件复制到MrDoc的静态文件目录中(也可以使用其他的XML样式文件):

自定义Django默认的sitemap站点地图样式

然后在模板目录template文件下新建了两个同名的XML文件:

自定义Django默认的sitemap站点地图样式

在原本的sitemap模板文件内容中添加一行xml-stylesheet标签代码,用于指示XML样式文件的路径:

自定义Django默认的sitemap站点地图样式

最后,修改urls.py文件,使用template_name键指定自定义sitemap模板的名称:

path('sitemap.xml', views.index, {'sitemaps': sitemaps},name='sitemap',), # 站点地图索引
path('sitemap-<section>.xml', views.sitemap, {'sitemaps': sitemaps}, # 站点地图
  name='django.contrib.sitemaps.views.sitemap')

这样,我们的sitemap站点地图就是有样式渲染的页面了,如下图所示:

自定义Django默认的sitemap站点地图样式

是不是比最开始的简陋页面要好多了?源码地址为: https://gitee.com/zmister/MrDoc

总结

到此这篇关于自定义Django默认的sitemap站点地图样式的文章就介绍到这了,更多相关Django Sitemap 站点地图内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Numpy之random函数使用学习
Jan 29 Python
对IPython交互模式下的退出方法详解
Feb 16 Python
flask框架jinja2模板与模板继承实例分析
Aug 01 Python
Pytorch 实现自定义参数层的例子
Aug 17 Python
Python原始套接字编程实例解析
Jan 29 Python
Python异步编程之协程任务的调度操作实例分析
Feb 01 Python
django自定义非主键自增字段类型详解(auto increment field)
Mar 30 Python
如何基于Python Matplotlib实现网格动画
Jul 20 Python
Python编写memcached启动脚本代码实例
Aug 14 Python
Python中Yield的基本用法
Oct 18 Python
使用Python爬虫爬取小红书完完整整的全过程
Jan 19 Python
python状态机transitions库详解
Jun 02 Python
Python 窗体(tkinter)下拉列表框(Combobox)实例
Mar 04 #Python
Python3中的f-Strings增强版字符串格式化方法
Mar 04 #Python
Python MySQLdb 执行sql语句时的参数传递方式
Mar 04 #Python
python3格式化字符串 f-string的高级用法(推荐)
Mar 04 #Python
利用Python脚本批量生成SQL语句
Mar 04 #Python
一文了解python 3 字符串格式化 F-string 用法
Mar 04 #Python
Python正则表达式学习小例子
Mar 03 #Python
You might like
php动态生成版权所有信息的方法
2015/03/24 PHP
php监测数据是否成功插入到Mysql数据库的方法
2016/11/25 PHP
解决form中action属性后面?传递参数 获取不到的问题
2017/07/21 PHP
写的htc的数据表格
2007/01/20 Javascript
js 数组操作代码集锦
2009/04/28 Javascript
js下获得客户端操作系统的函数代码(1:vista,2:windows7,3:2000,4:xp,5:2003,6:2008)
2011/10/31 Javascript
详解强大的jQuery选择器之基本选择器、层次选择器
2012/02/07 Javascript
jquery 如何动态添加、删除class样式方法介绍
2012/11/07 Javascript
jQuery实现列表自动循环滚动鼠标悬停时停止滚动
2013/09/06 Javascript
ExtJS[Desktop]实现图标换行示例代码
2013/11/17 Javascript
js动态删除div元素基本思路及实现代码
2014/05/08 Javascript
纯javascript实现的小游戏《Flappy Pig》实例
2015/07/27 Javascript
Js操作DOM元素及获取浏览器高宽的简单方法
2016/09/08 Javascript
js 中文汉字转Unicode、Unicode转中文汉字、ASCII转换Unicode、Unicode转换ASCII、中文转换
2016/12/06 Javascript
Node.js 实现简单的接口服务器的实例代码
2017/05/23 Javascript
es7学习教程之fetch解决异步嵌套问题的方法示例
2017/07/21 Javascript
JavaScript中递归实现的方法及其区别
2017/09/12 Javascript
10分钟彻底搞懂Http的强制缓存和协商缓存(小结)
2018/08/30 Javascript
vue 之 css module的使用方法
2018/12/04 Javascript
js中的深浅拷贝问题简析
2019/05/10 Javascript
vue滚动tab跟随切换效果
2020/06/29 Javascript
解决vue打包后刷新页面报错:Unexpected token
2019/08/27 Javascript
在antd Form表单中select设置初始值操作
2020/11/02 Javascript
python的mysqldb安装步骤详解
2017/08/14 Python
pandas对指定列进行填充的方法
2018/04/11 Python
将Python文件打包成.EXE可执行文件的方法
2019/08/11 Python
Python matplotlib生成图片背景透明的示例代码
2019/08/30 Python
美国生鲜及杂货电商:FreshDirect
2018/01/29 全球购物
盖尔斯工厂店:GUESS Factory
2020/01/21 全球购物
优秀团干部个人事迹
2014/05/29 职场文书
2015年全国助残日活动方案
2015/05/04 职场文书
加薪申请报告范本
2015/05/15 职场文书
2015年安全生产管理工作总结
2015/05/25 职场文书
黄埔军校观后感
2015/06/10 职场文书
《槐乡的孩子》教学反思
2016/02/20 职场文书
创业计划书之干洗店
2019/09/10 职场文书