国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Django渲染Markdown文章目錄的方法示例

2020-01-04 13:38:29
字體:
來源:轉載
供稿:網友

對會讀書的人來說,讀一本書要做的第一件事,就是仔細閱讀這本書的目錄。閱讀目錄可以對整體內容有所了解,并清楚地知道感興趣的部分在哪里,提高閱讀質量。

博文也是同樣的,好的目錄對博主和讀者都很有幫助。更進一步的是,還可以在目錄中設置錨點,點擊標題就立即前往該處,非常的方便。

文中的目錄

之前我們已經為博文支持了Markdown語法,現在繼續增強其功能。

有折騰代碼高亮的痛苦經歷之后,設置Markdown的目錄擴展就顯得特別輕松了。

修改文章詳情視圖:

article/views.py...# 文章詳情def article_detail(request, id): ... article.body = markdown.markdown(article.body,  extensions=[  'markdown.extensions.extra',  'markdown.extensions.codehilite',     # 目錄擴展  'markdown.extensions.TOC',  ] ) ...

僅僅是將將markdown.extensions.TOC擴展添加了進去。

TOC: Table of Contents,即目錄的意思

代碼增加這一行就足夠了。為了方便測試,往之前的文章中添加幾個一級標題、二級標題等。

還記得Markdown語法如何寫標題嗎?一級標題:# title1,二級標題:## title2

然后你可以在文中的任何地方插入[TOC]字符串,目錄就自動生成好了:

Django,渲染,Markdown,文章目錄

點擊標題,頁面就立即前往相應的標題處(即“錨點”的概念)。

任意位置的目錄

上面的方法只能將目錄插入到文章當中。如果我想把目錄插入到頁面的任何一個位置呢?

也簡單,這次需要修改Markdown的渲染方法:

article/views.py...def article_detail(request, id): ... # 修改 Markdown 語法渲染 md = markdown.Markdown(  extensions=[  'markdown.extensions.extra',  'markdown.extensions.codehilite',  'markdown.extensions.toc',  ] ) article.body = md.convert(article.body) # 新增了md.toc對象 context = { 'article': article, 'toc': md.toc } return render(request, 'article/detail.html', context)

為了能將toc單獨提取出來,我們先將Markdown類賦值給一個臨時變量md,然后用convert()方法將正文渲染為html頁面。通過md.toc將目錄傳遞給模板。

注意markdown.markdown()和markdown.Markdown()的區別

更詳細的解釋見:官方文檔

為了將新的目錄渲染到頁面中,需要修改文章詳情模板:

templates/article/detail.html...<div class="container"> <div class="row">  <!-- 將原有內容嵌套進新的div中 -->  <div class="col-9">   <h1 class="mt-4 mb-4">{{ article.title }}</h1>   <div class="alert alert-success">    ...   </div>  </div>  <!-- 新增的目錄 -->  <div class="col-3 mt-4">   <h4><strong>目錄</strong></h4>   <hr>   <div>    {{ toc|safe }}   </div>  </div> </div></div>...
  • 重新布局,將原有內容裝進col-9的容器中,將右側col-3的空間留給目錄
  • toc需要|safe標簽才能正確渲染

重新打開頁面:

Django,渲染,Markdown,文章目錄

總結

完成了文章的目錄功能,至此文章詳情頁面也比較完善了。

項目完整代碼:Django_blog_tutorial

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 安阳市| 闽清县| 荔波县| 贺兰县| 北票市| 嫩江县| 汕尾市| 义乌市| 连州市| 隆昌县| 外汇| 邵武市| 五华县| 台前县| 潮安县| 德庆县| 洛宁县| 河北省| 定西市| 修文县| 栾城县| 宜阳县| 格尔木市| 玉屏| 临西县| 无锡市| 元朗区| 鹿邑县| 安平县| 武功县| 文水县| 淮南市| 鹰潭市| 白城市| 左云县| 揭西县| 澄城县| 景宁| 乐昌市| 广南县| 广南县|