利用Django模版生成樹(shù)狀結(jié)構(gòu)實(shí)例代碼
前言
我們經(jīng)常會(huì)有這樣的需求,比如評(píng)論功能,每個(gè)評(píng)論都有可能會(huì)有自己的子評(píng)論,如果在界面只展示成一列的話非常不美觀,也不能體現(xiàn)出他們的層級(jí)關(guān)系。那么我們今天就來(lái)看看如何使用Django的模版來(lái)生成樹(shù)狀結(jié)構(gòu),以本站為例,效果如下圖所示:
那么我們要怎么實(shí)現(xiàn)呢?首先先看看評(píng)論實(shí)體的定義,如下所示:
class Comment(models.Model): body = models.TextField('正文', max_length=300) author = models.ForeignKey(settings.AUTH_USER_MODEL, verbose_name='作者', on_delete=models.CASCADE) article = models.ForeignKey(Article, verbose_name='文章', on_delete=models.CASCADE) parent_comment = models.ForeignKey('self', verbose_name="上級(jí)評(píng)論", blank=True, null=True, on_delete=models.CASCADE)
可以看到,有一個(gè)parent_comment字段,關(guān)聯(lián)自己。這樣就可以根據(jù)這個(gè)字段來(lái)生成層級(jí)關(guān)系。 為了方便我們使用,我們自定義了一個(gè)叫query的tag,也可以叫修飾器。定義tag的代碼如下,tag的定義應(yīng)該定義在app/templatetags目錄下,這里py文件命名為blog_tags.py:
@register.simple_tag def query(qs, **kwargs): """ template tag which allows queryset filtering. Usage: {% query books author=author as mybooks %} {% for book in mybooks %} ... {% endfor %} """ return qs.filter(**kwargs)
接下來(lái)下面這段代碼是樹(shù)節(jié)點(diǎn)的模版代碼。
{% load blog_tags %} {% load comments_tags %} <div id="commentlist-container" class="comment-tab" style="display: block;"> <ol class="commentlist"> {% query article_comments parent_comment=None as parent_comments %} {% for comment_item in parent_comments %} {% with 0 as depth %} {% include "comments/tags/comment_item_tree.html" %} {% endwith %} {% endfor %} </ol> </div>
其中的{% query article_comments parent_comment=None as parent_comments %}
的功能就是從評(píng)論中篩選出來(lái)是父級(jí)的評(píng)論。 comment_item_tree.html的實(shí)現(xiàn)也很簡(jiǎn)單:
{% load blog_tags %} <li class="comment even thread-even depth-{{ depth }} parent" id="comment-{{ comment_item.pk }}" style="margin-left: {% widthratio depth 1 3 %}rem"> <div id="div-comment-{{ comment_item.pk }}" class="comment-body"> <div class="comment-meta commentmetadata"> {{ comment_item.created_time }} </div> <p>{{ comment_item.body |escape|custom_markdown }}</p> <div class="reply"><a class="comment-reply-link" href="javascript:void(0)" rel="external nofollow" onclick="do_reply({{ comment_item.pk }})" aria-label="回復(fù)給{{ comment_item.author.username }}">回復(fù)</a></div> </div> </li><!-- #comment-## --> {% query article_comments parent_comment=comment_item as cc_comments %} {% for cc in cc_comments %} {% with comment_item=cc template_name="comments/tags/comment_item_tree.html" %} {% with depth=depth|add:1 %} {% include template_name %} {% endwith %} {% endwith %} {% endfor %}
其中最主要的部分就是</li>標(biāo)簽后面那段。這里使用with和include配合來(lái)在每一次循環(huán)里面重復(fù)的引入comment_item_tree.html,并且每次引入時(shí)賦予當(dāng)前的評(píng)論變量和depth(每層循環(huán)depth會(huì)+1)。然后在每個(gè)評(píng)論處使用style="margin-left: {% widthratio depth 1 3 %}rem"
來(lái)實(shí)現(xiàn)縮進(jìn),這樣就實(shí)現(xiàn)了樹(shù)狀顯示。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
python+selenium實(shí)現(xiàn)登錄賬戶后自動(dòng)點(diǎn)擊的示例
本篇文章主要介紹了python+selenium實(shí)現(xiàn)登錄賬戶后自動(dòng)點(diǎn)擊的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-12-12Python 用Redis簡(jiǎn)單實(shí)現(xiàn)分布式爬蟲(chóng)的方法
本篇文章主要介紹了Python 用Redis簡(jiǎn)單實(shí)現(xiàn)分布式爬蟲(chóng)的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11python對(duì)ip地址進(jìn)行排序、分類的方法詳解
這篇文章主要介紹了python對(duì)ip地址進(jìn)行排序、分類的方法詳解,IP協(xié)議全稱為“網(wǎng)際互連協(xié)議Internet?Protocol”,IP協(xié)議是TCP/IP體系中的網(wǎng)絡(luò)層協(xié)議,需要的朋友可以參考下2023-07-07Python爬取股票信息,并可視化數(shù)據(jù)的示例
這篇文章主要介紹了Python爬取股票信息,并可視化數(shù)據(jù)的示例,幫助大家更好的理解和使用python爬蟲(chóng),感興趣的朋友可以了解下2020-09-09使用python?AI快速比對(duì)兩張人臉圖像及遇到的坑
這篇文章主要介紹了如何使用python?AI快速比對(duì)兩張人臉圖像?實(shí)現(xiàn)過(guò)程比較簡(jiǎn)單,但是第三方python依賴的安裝過(guò)程較為曲折,下面是通過(guò)實(shí)踐對(duì)比總結(jié)出來(lái)的能夠支持的幾個(gè)版本,避免大家踩坑,需要的朋友可以參考下2023-02-02python基礎(chǔ)知識(shí)之私有屬性和私有方法
這篇文章主要介紹了python基礎(chǔ)知識(shí)之私有屬性和私有方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03詳解python實(shí)現(xiàn)識(shí)別手寫(xiě)MNIST數(shù)字集的程序
這篇文章主要介紹了詳解python實(shí)現(xiàn)識(shí)別手寫(xiě)MNIST數(shù)字集的程序,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08