自定義Django默認(rèn)的sitemap站點(diǎn)地圖樣式
Django 中自帶了 sitemap框架,用來(lái)生成 xml 文件
Sitemap(站點(diǎn)地圖)是通知搜索引擎頁(yè)面的地址,頁(yè)面的重要性,幫助站點(diǎn)得到比較好的收錄。 白話文就是:一個(gè)寫(xiě)了你網(wǎng)站的所有url的xml文件,告訴搜索引擎,請(qǐng)及時(shí)收錄我的這些地址。
sitemap 很重要,可以用來(lái)通知搜索引擎頁(yè)面的地址,頁(yè)面的重要性,幫助站點(diǎn)得到比較好的收錄。
一、站點(diǎn)地圖sitemap一般在Web網(wǎng)站開(kāi)發(fā)完成之際,如果對(duì)搜索引擎優(yōu)化(SEO)有一定的要求,我們都會(huì)為網(wǎng)站添加一個(gè)站點(diǎn)地圖sitemap,配合robot.txt的使用,以匯總和索引網(wǎng)站上所有允許被搜索引擎搜索、采集和索引的網(wǎng)頁(yè),這樣搜索引擎可以根據(jù)站點(diǎn)地圖快速地爬取到一個(gè)網(wǎng)站上的所有希望被收錄的網(wǎng)址。
在Django框架中,有一個(gè)自帶且基本完整的sitemap框架供我們使用。通過(guò)Django提供的sitemap,我們可以很快實(shí)現(xiàn)是個(gè)站點(diǎn)地圖的功能。
二、使用Django的sitemap功能Django自帶的sitemap使用起來(lái)非常簡(jiǎn)單,總結(jié)起來(lái)就是3步。下面,我們以MrDoc中的使用為例。
第一步,新建一個(gè)在應(yīng)用文件夾下新建一個(gè)名為sitemap.py的文件(在MrDoc中的路徑為/MrDoc/app_doc/sitemap.py),根據(jù)實(shí)際站點(diǎn)的需求,我們準(zhǔn)備將首頁(yè)、公開(kāi)的文集和已發(fā)布的文檔,放到sitemap中,所以我們要寫(xiě)實(shí)例化幾個(gè)Sitemap類,先來(lái)引入它:
# MrDoc Sitemap.pyfrom django.contrib.sitemaps import Sitemapfrom django.urls import reversefrom app_doc.models import Doc,Project
定義一個(gè)繼承自SiteMap的類,用來(lái)生成首頁(yè)的sitemap:
接著定義一個(gè)文檔的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,我們通過(guò)調(diào)用文檔的sitemap來(lái)生成:
在sitemap.py文件中的操作就完成了,我們移步到Django項(xiàng)目的頂級(jí)URL路由文件urls.py中(在MrDoc中的路徑為/MrDoc/MrDoc/urls.py),進(jìn)行第二步。
引入相關(guān)的模塊:
from django.contrib.sitemaps import viewsfrom app_doc.sitemaps import all_sitemaps as sitemaps
然后在urlpatterns中添加兩個(gè)URL的匹配路徑:
path(’sitemap.xml’, views.index, {’sitemaps’: sitemaps},name=’sitemap’,), # 站點(diǎn)地圖索引path(’sitemap-<section>.xml’, views.sitemap, {’sitemaps’: sitemaps}, # 站點(diǎn)地圖 name=’django.contrib.sitemaps.views.sitemap’)
最后一步,我們?cè)趕etting.py文件中(在MrDoc中的路徑為/MrDoc/MrDoc/settings.py)的應(yīng)用列表INSTALLED_APPS中將sitemap的功能應(yīng)用添加進(jìn)去:
這樣,為Django創(chuàng)建的網(wǎng)站添加sitemap站點(diǎn)地圖功能就已經(jīng)完成了。我們運(yùn)行服務(wù),訪問(wèn)127.0.0.1/sitemap.xml就可以看到站點(diǎn)地圖:
這就是Django自帶的sitemap的樣子了。
站點(diǎn)地圖是出來(lái)了,但是和我們平常在一些網(wǎng)站上看到了似乎不太一樣,不僅不能點(diǎn)擊上面的鏈接,樣式也是很簡(jiǎn)單的XML結(jié)構(gòu)樹(shù)。而州的先生博客(https://zmister.com)網(wǎng)站上的站點(diǎn)地圖就要美觀好看得多:
如果把Django自帶的sitemap站點(diǎn)地圖美化一下呢?我們可以借助Django提供了自定義sitemap模板功能。
三、自定義sitemap模板在Django中,sitemap的樣式存在于djangocontribsitemapstemplates文件夾下,一共有兩個(gè)XML模板文件:
sitemap.xml sitemap-index.xml我們需要做的就是新建兩個(gè)xml文件,在上述兩個(gè)文件的基礎(chǔ)之上,引入XML的樣式文件,讓XML樣式文件對(duì)XML文件進(jìn)行渲染,以實(shí)現(xiàn)美化sitemap站點(diǎn)地圖的功能。
我們首先從州的先生博客(https://zmister.com)上把站點(diǎn)地圖的樣式文件復(fù)制到MrDoc的靜態(tài)文件目錄中(也可以使用其他的XML樣式文件):
然后在模板目錄template文件下新建了兩個(gè)同名的XML文件:
在原本的sitemap模板文件內(nèi)容中添加一行xml-stylesheet標(biāo)簽代碼,用于指示XML樣式文件的路徑:
最后,修改urls.py文件,使用template_name鍵指定自定義sitemap模板的名稱:
path(’sitemap.xml’, views.index, {’sitemaps’: sitemaps},name=’sitemap’,), # 站點(diǎn)地圖索引path(’sitemap-<section>.xml’, views.sitemap, {’sitemaps’: sitemaps}, # 站點(diǎn)地圖 name=’django.contrib.sitemaps.views.sitemap’)
這樣,我們的sitemap站點(diǎn)地圖就是有樣式渲染的頁(yè)面了,如下圖所示:
是不是比最開(kāi)始的簡(jiǎn)陋頁(yè)面要好多了?源碼地址為: https://gitee.com/zmister/MrDoc
總結(jié)
到此這篇關(guān)于自定義Django默認(rèn)的sitemap站點(diǎn)地圖樣式的文章就介紹到這了,更多相關(guān)Django Sitemap 站點(diǎn)地圖內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. python 批量下載bilibili視頻的gui程序2. 詳解Vue中Axios封裝API接口的思路及方法3. python thrift 實(shí)現(xiàn) 單端口多服務(wù)的過(guò)程4. CSS自定義滾動(dòng)條樣式案例詳解5. python中HTMLParser模塊知識(shí)點(diǎn)總結(jié)6. python中if嵌套命令實(shí)例講解7. python:刪除離群值操作(每一行為一類數(shù)據(jù))8. 使用css實(shí)現(xiàn)全兼容tooltip提示框9. python 通過(guò)exifread讀取照片信息10. JSP實(shí)現(xiàn)客戶信息管理系統(tǒng)
