首页
学习
活动
专区
圈层
工具
发布

Django学习_简易博客(六)

创建自定义模版标签

  • simple_tag 处理数据并返回一个字符串
  • inclusion_tag 处理数据并返回所显示的模版

每个模版标签模块都需要定义一个register变量作为有效的标签库。

blog/templatetags/blog_tags.py

代码语言:javascript
代码运行次数:0
复制
from django import template
from ..models import Post
from django.db.models import Count
from django.utils.safestring import mark_safe
import markdown

register = template.Library()


@register.simple_tag #注册为简单的标签
def total_posts():
    return Post.published.count()


@register.inclusion_tag('blog/post/latest_posts.html')
def show_latest_posts(count=5):
    latest_posts = Post.published.order_by('-publish')[:count]
    return {'latest_posts': latest_posts}


@register.simple_tag
def get_most_commented_posts(count=5):
    return Post.published.annotate(
        total_comments=Count('comments')
    ).order_by('-total_comments')[:count]


@register.filter(name='markdown')
def markdown_format(text):
    return mark_safe(markdown.markdown(text))

blog/post/latest_posts.html

代码语言:javascript
代码运行次数:0
复制
<ul>
    {% for post in latest_posts %}
        <li>
            <a href="{{ post.get_absolute_url }}">{{ post.title }}</a>
        </li>
    {% endfor %}
</ul>

使用标签

  • 在html文件上使用total_posts
代码语言:javascript
代码运行次数:0
复制
{% load blog_tags %}
<p>This is my blog. I`ve written {% total_posts %} posts so far.</p>

效果

  • 在html文件上使用show_latest_posts
代码语言:javascript
代码运行次数:0
复制
<h3>Latest posts</h3>
{% show_latest_posts 3 %}

效果

  • 在html文件上使用get_most_commented_posts
代码语言:javascript
代码运行次数:0
复制
<h3>Most commented posts</h3>
{% get_most_commented_posts as most_commented_posts %}
<ul>
    {% for post in most_commented_posts %}
        <li>
            <a href="{{ post.get_absolute_url }}">{{ post.title }}</a>
        </li>
    {% endfor %}
</ul>

效果

整体

整体

创建自定义模版过滤器

代码语言:javascript
代码运行次数:0
复制
$ pip install Markdown==2.6.11

在博客内使用Markdown语法

代码语言:javascript
代码运行次数:0
复制
@register.filter(name='markdown')
def markdown_format(text):
    return mark_safe(markdown.markdown(text))
代码语言:javascript
代码运行次数:0
复制
{{ post.body|truncatewords:30|linebreaks }}
替换为
{{ post.body|markdown|truncatewords_html:30 }}

{{ post.body|linebreaks }}
替换为
{{ post.body|markdown }}
举报
领券