Django 个人博客 - 详情页面 - step7

知识点

各个小模块点击以后有可能会发生跳转到对应的页面,这里主要有3个小模块,标签云、文章归档和文章的详情页面需要添加。主要思路是,点击后发生请求,后端获取到前端的请求再做出响应。

1 标签云详情页

前端请求的href【tags.html】

<li><a href='{% url "biaoqian" %}?tag={{ tag }}'>{{ tag }}</a></li>

请求到了路由【urls.py】

from django.conf.urls import url
from blog.views import biaoqian

urlpatterns = [
    url(r'^biaoqian$', biaoqian, name='biaoqian'),
]

路由将请求转给视图【views.py】

def biaoqian(request):
    try:
        # 获取请求的tag参数
        tag_name = request.GET.get('tag', None)
        # 找到tag所对应的Tag对象
        tag_obj = Tag.objects.get(name=tag_name)
        # 使用_set通过一对多关系进行查找
        article_list = tag_obj.article_set.all()
    except Exception as e:
        logging.error(e)
    return render(request, 'biaoqian.html', locals())

视图将数据传递给前段模板渲染【biaoqian.html】

{% extends 'base.html' %}
{% load staticfiles %}
{% block left_content %}
{% include 'baseblock/ads.html' %}
<!-- banner代码 结束 -->
<div class="topnews">
    <h2>{{ request.GET.tag }} 标签云</h2>
    {% for article in article_list%}
    <div class="blogs">
        <ul>
            <h3><a href="/">{{ article.title }}</a></h3>
            <p>{{ article.desc }}</p>
            <p class="autor">
                <span class="lm f_l">
                    {% for tag in article.tag.all %}
                    <a href="/">{{ tag.name }}</a> 
                    {% endfor %}
                </span>
                <span class="dtime f_l">{{ article.date_publish | date:'Y-m-d' }}</span>
                <span class="viewnum f_r">浏览(<a href="/">{{ article.click_count }}</a>)</span>
                <span class="pingl f_r">评论(<a href="/">{{ article.comment_set.all.count }}</a>)</span>
            </p>
        </ul>
    </div>
    {% endfor %}
</div>
{% endblock %}

2 文章归档详情页(方法与标签云类似)

前端请求的href【sorts.html】
silce切片类似于[:4],获取需要的数据

<li><p><span class="tutime font-size-18"><a href='{% url "archive" %}?year={{ article_date | slice:":4" }}&month={{ article_date | slice:"7:9" }}'>{{ article_date }}</a></span></p></li>

请求转到路由【urls.py】

from django.conf.urls import url
from blog.views import archive

urlpatterns = [
    url(r'^archive$', archive, name='archive'),
]

路由将请求转给视图【views.py】

def archive(request):
    try:
        # 先获取用户提交的year和month信息
        year = request.GET.get('year', None)
        month = request.GET.get('month', None)
        # 通过filter过滤出对应年份的数据(icontains是包含)
        article_list = Article.objects.filter(date_publish__icontains=year + '-' + month)
    except Exception as e:
        logging.error(e)
    return render(request, 'archive.html', locals())

视图将数据传递给前段模板渲染【atchive.html】

{% extends 'base.html' %}
{% load staticfiles %}
{% block left_content %}
{% include 'baseblock/ads.html' %}
<!-- banner代码 结束 -->
<div class="topnews">
    <h2>{{ request.GET.year }}年{{ request.GET.month }}月 归档文章</h2>
    {% for article in article_list%}
    <div class="blogs">
        <ul>
            <h3><a href="/">{{ article.title }}</a></h3>
            <p>{{ article.desc }}</p>
            <p class="autor">
                <span class="lm f_l">
                    {% for tag in article.tag.all %}
                    <a href="/">{{ tag.name }}</a> 
                    {% endfor %}
                </span>
                <span class="dtime f_l">{{ article.date_publish | date:'Y-m-d' }}</span>
                <span class="viewnum f_r">浏览(<a href="/">{{ article.click_count }}</a>)</span>
                <span class="pingl f_r">评论(<a href="/">{{ article.comment_set.all.count }}</a>)</span>
            </p>
        </ul>
    </div>
    {% endfor %}
</div>
{% endblock %}

3 文章详情页面设计

前端请求的href【sorts.html】
总共有3个地方:博客首页、文章排行、归档详情页面

## index.html【博客首页】
<h3><a href='{% url "article" %}?id={{ article.id }}'>{{ article.title }}</a></h3>

## chart.html【文章排行】
<li><a href='{% url "article" %}?id={{ article_click.id }}' target="_blank">{{ article_click }}</a></li>
<li><a href='{% url "article" %}?id={{ article_comment.id }}' target="_blank">{{ article_comment }}</a></li>
<li><a href='{% url "article" %}?id={{ article_recommend.id }}' target="_blank">{{ article_recommend }}</a></li>

## archive.html【归档详情页面】
<h3><a href='{% url "article" %}?id={{ article.id }}'>{{ article.title }}</a></h3>

请求转到路由【urls.py】

from django.conf.urls import url
from blog.views import article

urlpatterns = [
    url(r'^article/$', article, name='article'),
]

路由将请求转给视图【views.py】

# 文章详情
def article(request):
    try:
        # 获取文章id
        id = request.GET.get('id', None)
        try:
            # 获取文章信息
            article = Article.objects.get(pk=id)
        except Article.DoesNotExist:
            return render(request, 'failure.html', {'reason': '没有找到对应的文章'})
    except Exception as e:
        print e
        logging.error(e)
    return render(request, 'article.html', locals())

app下面新建一个templatetags目录自定义过滤器【myfilter.py】

# -*- coding: utf-8 -*-
from django import template
register = template.Library()

# 定义一个将日期中的月份转换为大写的过滤器,如8转换为八
@register.filter
def month_to_upper(key):
        return ['一', '二', '三', '四', '五', '六', '七', '八', '九', '十', '十一', '十二'][key.month-1]

视图将数据传递给前段模板渲染【article.html】
这里使用了自定义的过滤器获取对应月份的大写

{% extends 'base.html' %}
{% load staticfiles %}
{% load myfilter %}
{% block left_content %}
<div class="postdate">
    <div class="month">{{ article.date_publish | month_to_upper }}</div>
    <div class="date">{{ article.date_publish | date:'d' }}</div>
</div>
<div class="title">
    <h2><a href="" rel="bookmark" title="{{ article.title }}">{{ article.title }}</a></h2>
    <div class="postmeta">
        <span class="postmeta_author">{{ article.user.username }}</span>
        <span class="postmeta_category"><a href="" rel="category">{{ article.category.name }}</a></span>
        <span class="postmeta_time">{{ article.date_publish | date:'Y-m-d' }}</span>
    </div>
</div>
<div class="entry">
    {{ article.content | safe }}
</div>
<span class="tags">
    {% for tag in article.tag.all %}
    <a href="?tag={{ tag.name }}" rel="tag">{{ tag.name }}</a>
    {% endfor %}
</span>
{% endblock %}

相关下载

详情页面_代码


欢迎留言,博文会持续更新~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容