inclusion_tag。它多用于一个HTML片段的。例如我写的一个BBS项目中。

一个博主的主页面的左侧栏和查看博主某篇文章的页面的左栅栏的一样的。为了不用重复写同样的代码。且提高页面的扩展性。我的bbs的左侧栏就用了inclusion_tag来实现。

首先要在项目的:

在项目blog这个app下面创建一个templatetags文夹。这个文件夹的名字必顺是templatetags来命名的。然后在此文件夹下自定义一个matag.py文件。

  1.  
    from django import template
  2.  
    from blog import models
  3.  
    from django.db.models import Count
  4.  
     
  5.  
    register=template.Library()
  6.  
    @register.inclusion_tag('left_tag.html')
  7.  
    def left_panel(username):
  8.  
    user_obj = models.UserInfo.objects.filter(username=username).first()
  9.  
    blog = user_obj.blog
  10.  
    # 文章分类
  11.  
    category_article_list = models.Category.objects.filter(blog=blog).annotate(num=Count('article')).values('title', 'num')
  12.  
    # 标签分类
  13.  
    tag_article_list = models.Tag.objects.filter(blog=blog).annotate(num=Count('article')).values('title', 'num')
  14.  
    # 时间分类auth_group
  15.  
    time_archive_list = models.Article.objects.filter(user__username=username).extra(
  16.  
    select={'ym': 'DATE_FORMAT(create_time,"%%Y-%%m")'}
  17.  
    ).values('ym').annotate(num=Count('nid')).values('ym', 'num')
  18.  
     
  19.  
    return {
  20.  
    'username': username,
  21.  
    'category_article_list': category_article_list,
  22.  
    'tag_article_list': tag_article_list,
  23.  
    'time_archive_list': time_archive_list,
  24.  
    }

然后写一个left_tag.html代码块。

  1.  
    <div class="panel panel-primary">
  2.  
    <div class="panel-heading">
  3.  
    <h3 class="panel-title">文章分类</h3>
  4.  
    </div>
  5.  
     
  6.  
    <div class="panel-body">
  7.  
    <ul class="panel-ul">
  8.  
    {% if not category_article_list %}
  9.  
    <li>没有此分类</li>
  10.  
    {% else %}
  11.  
    {% for category_article in category_article_list %}
  12.  
    <li><a href="/blog/{{ username }}/category/{{ category_article.title }}">{{ category_article.title }}({{ category_article.num }})</a></li>
  13.  
    {% endfor %}
  14.  
    {% endif %}
  15.  
    </ul>
  16.  
    </div>
  17.  
    </div>
  18.  
    <div class="panel panel-success">
  19.  
    <div class="panel-heading">
  20.  
    <h3 class="panel-title">标签分类</h3>
  21.  
    </div>
  22.  
    <div class="panel-body">
  23.  
    <ul class="panel_ul">
  24.  
    {% if not tag_article_list %}
  25.  
    <li>没有此分类</li>
  26.  
    {% else %}
  27.  
    {% for tag_article in tag_article_list %}
  28.  
    <li><a href="/blog/{{ username }}/tag/{{ tag_article.title }}">{{ tag_article.title }}({{ tag_article.num }})</a></li>
  29.  
    {% endfor %}
  30.  
    {% endif %}
  31.  
    </ul>
  32.  
    </div>
  33.  
    </div>
  34.  
    <div class="panel panel-info">
  35.  
    <div class="panel-heading">
  36.  
    <h3 class="panel-title">时间归档</h3>
  37.  
    </div>
  38.  
    <div class="panel-body">
  39.  
    <ul class="pane_ul">
  40.  
    {% if not time_archive_list %}
  41.  
    <li>没有此分类</li>
  42.  
    {% else %}
  43.  
    {% for time_archive in time_archive_list %}
  44.  
    <li><a href="/blog/{{ username }}/archive/{{ time_archive.ym }}">{{ time_archive.ym }}({{ time_archive.num }})</a></li>
  45.  
    {% endfor %}
  46.  
    {% endif %}
  47.  
    </ul>
  48.  
    </div>
  49.  
    </div>

最后就简单了。一些页面在需要用到这个左侧栏的就加上下面的一小段代码就好了。

  1.  
    {% load mytag %}
  2.  
    {% left_panel username %}

上面的代码中username是一个参数。

Django模版语言inclusion_tag的用法。的更多相关文章

  1. Django模版语言的复用 1. include标签--模版导入 2.inclusion_tag自定义标签--模版导入 3.母版

    include标签--模版导入 ''' 前提:项目中,往往会出现多个页面拥有一个或几个相同的页面版块,或是一个页面多个页面版块是相同的 如何运用:可以将多个样式标签的集合进行封装,对外提供版块的名字( ...

  2. Django模版语言 格式化显示 后台datatime()时间

    Django模版语言 格式化显示 后台datatime()时间 场景描述:

  3. django -- 模版语言之过滤器Filters和for循环

    前戏 在前面写的图书管理系统中,我们对模版语言应该已经不陌生了,使用{{ }}包裹起来的就是模版语言,只需要记住两种就可以了 {{ 变量名 }}            变量相关的 {% %}      ...

  4. Django 模版语言详解

    一.简介 模版是纯文本文件.它可以产生任何基于文本的的格式(HTML,XML,CSV等等). 模版包括在使用时会被值替换掉的 变量,和控制模版逻辑的 标签. 例: {% extends "b ...

  5. Django 模版语言

    传入变量 {{ 变量名 }} 在 view.py 的函数返回 render 时在html文件名后传入一个字典,字典的 key 对应html文件中的变量名,value 为传入的值 views.py: d ...

  6. Django模版语言自定义标签-实现前端 关联组合过滤查询

    前端关联 组合过滤查询 实现效果如图: models.py 创建表代码 from django.db import models # Create your models here. class Le ...

  7. Django - 模版语言循环字典

    1.可以对传入字典参数做循环显示 views.py中代码: urls.py中代码: html中代码: 在模版语言中,可以对字典进行类似python中的操作(keys,values,items),需要注 ...

  8. 第三章:模版层 - 1:Django模板语言详解

    本节将介绍Django模版系统的语法.Django模版语言致力于在性能和简单性上取得平衡. 如果你有过其它编程背景,或者使用过一些在HTML中直接混入程序代码的语言,那么你需要记住,Django的模版 ...

  9. Django模板语言详解

    本节将介绍Django模版系统的语法.Django模版语言致力于在性能和简单性上取得平衡. 如果你有过其它编程背景,或者使用过一些在HTML中直接混入程序代码的语言,那么你需要记住,Django的模版 ...

随机推荐

  1. Hadoop生态圈-zookeeper的API用法详解

    Hadoop生态圈-zookeeper的API用法详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.测试前准备 1>.开启集群 [yinzhengjie@s101 ~] ...

  2. 用vue前后端分离项目开发记录

    一:软件安装 1.1 检测node 是否安装 1.2 安装淘宝镜像 cnpm 1.3 安装vue-cli 1.4 检查是否安装vue-cli脚手架成功 1.5安装webpack 模块管理工具 二:创建 ...

  3. matplotlib交互模式与pacharm单独Figure设置

    matplotlib交互模式与pacharm单独Figure设置 觉得有用的话,欢迎一起讨论相互学习~Follow Me Matpotlib交互模式 在运行python程序时有时候需要生成以下的 动态 ...

  4. html5 canvas旋转+缩放

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. 第11月第21天 php引用 codeigniter cakephp

    1. class CI_Controller { private static $instance; /** * Constructor */ public function __construct( ...

  6. 使用 Application Loader提交IPA文件到苹果市场

    打包.导出ipa包后剩下的就是要将ipa包推到appstore.Application Loader是苹果提供的ipa包提交工具. 1.启动Application Loader 打开xcode,在xc ...

  7. LeetCode(19):删除链表的倒数第N个节点

    Medium! 题目描述: 给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点. 示例: 给定一个链表: 1->2->3->4->5, 和 n = 2. 当删除了 ...

  8. MySQL 数据库性能优化之SQL优化【转】

    优化目标 减少 IO 次数IO永远是数据库最容易瓶颈的地方,这是由数据库的职责所决定的,大部分数据库操作中超过90%的时间都是 IO 操作所占用的,减少 IO 次数是 SQL 优化中需要第一优先考虑, ...

  9. 关于vim复制剪贴粘贴命令的总结

    最近在使用vim,感觉很好很强大,但是在使用复制剪切粘贴命令是,碰到了一些小困惑,网上找了一些资料感觉很不全,讲的也不好,遂自己进行实践并总结了. 首先是剪切(删除): 剪切其实也就顺带删除了所选择的 ...

  10. 2017-2018-2 20155225《网络对抗技术》实验一 PC平台逆向破解

    2017-2018-2 20155225<网络对抗技术>实验一 PC平台逆向破解 1.直接修改程序机器指令,改变程序执行流程 理清思路: 我们的目标文件是一个linux可执行文件,格式为E ...