django 之个人主页框架实现

发布时间:2020-07-29 12:33:13 作者:kesungang
来源:网络 阅读:1668

上一节已经学习了,如何给时间,标签,分类,来分类。这一节学习下如何把这些内容写到页面上去
匹配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">
    <h4>文章分类</h4>
    <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">
    <h4>标签分类</h4>
    <ul>
        {% for tag in tag_list %}
            <li><a href="{{ tag.tag_id }}">{{ tag.tag__title }}({{ tag.ct }})</a></li>
        {% endfor %}

    </ul>
</div>

<div>
    <h4>时间标签</h4>
    <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>

预览
django 之个人主页框架实现

在主题里面通过link导入不同的css文件,给每个人设置不同的样式
django 之个人主页框架实现

推荐阅读:
  1. Django入门课程二
  2. Django 之 最基本的WEB框架

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

主页 框架 实现

上一篇:大学生学好python的小技巧

下一篇:bilibili高并发实时弹幕系统的实战之路

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》