Django 博客 - 6 标签、分类和归档页面

本文介绍了如何在Django中创建标签、分类和归档页面。首先,通过编写模板文件,利用Django的模板语言设置锚点和分组功能。然后,创建视图,使用ListView指定相关属性。最后,配置URL,使页面可以通过导航栏访问。通过这些步骤,实现了Django博客的扩展功能。
摘要由CSDN通过智能技术生成

编写模板文件

首先编写tag的模板,新建blog/templates/blog/tags.html文件,假设传给模版的上下文里有一个tags,代表所有标签,因此模板可以这么写

<ul>
    {% for tag in tags %}
    <li>
        <h3 id="{
   { tag.name }}">{
   { tag.name }}</h3>
        <ul>
            {% for post in tag.post_set.all %}
            <li><a href="{
   { post.get_absolute_url }}">{
   {post.title }}</a></li>
            {% endfor %}
        </ul>
    </li>
    {% endfor %}
</ul>

这里将id也设置为tag.name,主要是设置锚(archors),方便快速跳转
由于tagpost是多对一关系,通过tag.post_set.all,可以获取tag对应的所有文章

再使用UIKit3美化一下

{% extends 'blog/base.html' %}
{% block title %}Tags{% endblock %}
{% block body %}
    <div class="uk-container">
        <ul uk-accordion="multiple: true">
            {% for tag in tags %}
                <li class="uk-open">
                    <h3 class="uk-accordion-title" id="{
   { tag.name }}">{
   { tag.name }}</h3>
                    
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值