利用Django模版生成树状结构实例代码


Posted in Python onMay 19, 2019

前言

我们经常会有这样的需求,比如评论功能,每个评论都有可能会有自己的子评论,如果在界面只展示成一列的话非常不美观,也不能体现出他们的层级关系。那么我们今天就来看看如何使用Django的模版来生成树状结构,以本站为例,效果如下图所示:

利用Django模版生成树状结构实例代码

那么我们要怎么实现呢?首先先看看评论实体的定义,如下所示:

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="上级评论", blank=True, null=True, on_delete=models.CASCADE)

可以看到,有一个parent_comment字段,关联自己。这样就可以根据这个字段来生成层级关系。 为了方便我们使用,我们自定义了一个叫query的tag,也可以叫修饰器。定义tag的代码如下,tag的定义应该定义在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)

接下来下面这段代码是树节点的模版代码。

{% 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 %}的功能就是从评论中筛选出来是父级的评论。 comment_item_tree.html的实现也很简单:

{% 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="回复给{{ comment_item.author.username }}">回复</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>标签后面那段。这里使用with和include配合来在每一次循环里面重复的引入comment_item_tree.html,并且每次引入时赋予当前的评论变量和depth(每层循环depth会+1)。然后在每个评论处使用style="margin-left: {% widthratio depth 1 3 %}rem"来实现缩进,这样就实现了树状显示。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
Python语言技巧之三元运算符使用介绍
Mar 04 Python
python根据出生日期返回年龄的方法
Mar 26 Python
构建Python包的五个简单准则简介
Jun 15 Python
python多进程共享变量
Apr 06 Python
python解决网站的反爬虫策略总结
Oct 26 Python
深入理解python中sort()与sorted()的区别
Aug 29 Python
使用 Visual Studio Code(VSCode)搭建简单的Python+Django开发环境的方法步骤
Dec 17 Python
python画图--输出指定像素点的颜色值方法
Jul 03 Python
解决Python3下map函数的显示问题
Dec 04 Python
scrapy头部修改的方法详解
Dec 06 Python
Python机器学习之KNN近邻算法
May 14 Python
C3 线性化算法与 MRO之Python中的多继承
Oct 05 Python
使用Python3内置文档高效学习以及官方中文文档
May 19 #Python
python反编译学习之字节码详解
May 19 #Python
python从入门到精通 windows安装python图文教程
May 18 #Python
详解用Python实现自动化监控远程服务器
May 18 #Python
Python实现打砖块小游戏代码实例
May 18 #Python
如何在Python中实现goto语句的方法
May 18 #Python
OpenCV搞定腾讯滑块验证码的实现代码
May 18 #Python
You might like
一个没有MYSQL数据库支持的简易留言本的编写
2006/10/09 PHP
php提示undefined index的几种解决方法
2012/05/21 PHP
PHP Session 变量的使用方法详解与实例代码
2013/09/11 PHP
PHP中error_reporting函数用法详细介绍
2017/06/11 PHP
PHP观察者模式原理与简单实现方法示例
2017/08/25 PHP
PHP设计模式之装饰器模式实例详解
2018/02/07 PHP
php 实现银联商务H5支付的示例代码
2019/10/12 PHP
一直复略了的一个问题,关于表单重复提交
2007/02/15 Javascript
jQuery+CSS 半开折叠效果原理及代码(自写)
2013/03/04 Javascript
JQuery+CSS提示框实现思路及代码(纯手工打造)
2013/05/07 Javascript
jquery ajax 简单范例(界面+后台)
2013/11/19 Javascript
JSON字符串和对象之间的转换详解
2015/05/26 Javascript
借助FileReader实现将文件编码为Base64后通过AJAX上传
2015/12/24 Javascript
@ResponseBody 和 @RequestBody 注解的区别
2017/03/08 Javascript
Node中使用ES6语法的基础教程
2018/01/05 Javascript
webpack中使用iconfont字体图标的方法
2018/02/22 Javascript
Vue2.0 实现歌手列表滚动及右侧快速入口功能
2018/08/08 Javascript
vue移动端屏幕适配详解
2019/04/30 Javascript
JavaScript实现多张图片放大镜效果示例【不限定图片尺寸,rem单位】
2019/05/14 Javascript
微信小程序开发常见问题及解决方案
2019/07/11 Javascript
bootstrapValidator表单校验、更改状态、新增、移除校验字段的实例代码
2020/05/19 Javascript
使用Python3中的gettext模块翻译Python源码以支持多语言
2015/03/31 Python
用Python实现服务器中只重载被修改的进程的方法
2015/04/30 Python
Python如何实现定时器功能
2020/05/28 Python
python 实现客户端与服务端的通信
2020/12/23 Python
python 制作网站小说下载器
2021/02/20 Python
几款主流好用的富文本编辑器(所见即所得常用编辑器)介绍
2021/03/17 Javascript
北美领先的牛仔品牌:Buffalo David Bitton
2017/05/22 全球购物
Bugatchi官方网站:男士服装在线
2019/04/10 全球购物
一份婚庆公司创业计划书
2014/01/11 职场文书
校园创业策划书
2014/01/14 职场文书
中学生运动会入场词
2014/02/12 职场文书
关于梦想的演讲稿
2014/05/05 职场文书
我爱幼儿园演讲稿
2014/09/11 职场文书
小学总务工作总结
2015/08/13 职场文书
spring cloud 配置中心客户端启动遇到的问题
2021/09/25 Java/Android