码迷,mamicode.com
首页 > 其他好文 > 详细

django 之个人主页框架实现

时间:2018-04-19 12:01:01      阅读:97      评论:0      收藏:0      [点我收藏+]

标签:主页

上一节已经学习了,如何给时间,标签,分类,来分类。这一节学习下如何把这些内容写到页面上去
匹配url

url(r‘^(\w+)/$‘, views.home),

创建home函数

from django.db.models import Count
def home(request,site):
    blog = models.Blog.objects.filter(site=site).first()
    if not blog:
        return redirect(‘/‘)
    category_list = models.Article.objects.filter(blog=blog).values(‘category_id‘,‘category__title‘).annotate(ct=Count(‘nid‘))

    tag_list = models.Article2Tag.objects.filter(article__blog=blog).values(‘tag_id‘,‘tag__title‘).annotate(ct=Count(‘id‘))

    date_list = models.Article.objects.filter(blog=blog).extra(select={‘ctime‘:"strftime(‘%%Y-%%m‘,create_time)"}).values(‘ctime‘).annotate(ct=Count(‘nid‘))

    article_list = models.Article.objects.all()

    #return HttpResponse(‘......‘)

    return render(
        request,
        ‘home.html‘,
        {
            ‘blog‘:blog,
            ‘category_list‘:category_list,
            ‘tag_list‘:tag_list,
            ‘date_list‘:date_list,
            ‘article_list‘:article_list
        }
    )

创建home页面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" href="/static/css/theme/{{ blog.theme }}.css">
</head>
<body>
<div>{{ blog.title }}--{{ blog.user.nickname }}</div>
<div class="c1">
    <h3>文章分类</h3>
    <ul>
        {% for category in category_list %}
            <li><a href="{{ category.category_id }}">{{ category.category__title }}({{ category.ct }})</a></li>
        {% endfor %}
    </ul>
</div>
<div class="c2">
    <h3>标签分类</h3>
    <ul>
        {% for tag in tag_list %}
            <li><a href="{{ tag.tag_id }}">{{ tag.tag__title }}({{ tag.ct }})</a></li>
        {% endfor %}

    </ul>
</div>

<div>
    <h3>时间标签</h3>
    <ul>
        {% for date in date_list %}
        <li><a href="{{ date.ctime }}">{{ date.ctime }}({{ date.ct }})</a></li>
        {% endfor %}

    </ul>
</div>
<div>
    {% for article in article_list %}
        <div>
            <a href="{{ article.title }}"></a>
            <div>{{ article.summary }}</div>
        </div>

    {% endfor %}

</div>
</body>
</html>

预览
技术分享图片

在主题里面通过link导入不同的css文件,给每个人设置不同的样式
技术分享图片

django 之个人主页框架实现

标签:主页

原文地址:http://blog.51cto.com/sgk2011/2105256

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!