zoukankan      html  css  js  c++  java
  • 六、Django学习:设置博客列表和博客详情

    继续搭建博客,需要设置主页的博客列表与链接,详情页有主页链接用于返回,还需对博客数量进行统计。

    设置博客列表和博客详情

    • 编写blog views.py,增加blog_listblog_detail处理方式

    blog_list.html以及blog_detail.html需要在模板文件中另外建立

    from django.shortcuts import render_to_response,get_object_or_404
    from .models import Blog
    
    # Create your views here.
    
    def blog_list(request):
        context = {}
        context['blogs'] = Blog.objects.all()
        return render_to_response('blog_list.html', context)
    
    
    def blog_detail(request,blog_pk):
        context = {}
        context['blog'] = get_object_or_404(Blog, pk=blog_pk)
        return render_to_response('blog_detail.html', context)
    
    • 新建mysite templates文件夹,在templates文件夹下建立blog_list.html,blog_detail.html文件。

      • 编写blog_list.html文件

      别名blog_detail需要编写在路由中

      <!DOCTYPE html>
      <html>
      <head>
      	<title>我的博客</title>
      </head>
      <body>
      	{% for blog in blogs %}
      		<a href="{% url 'blog_detail' blog.pk %}">
      			<h3>{{ blog.title }}</h3>
      		</a>
      		<p>{{ blog.content }}</p>
      	{% endfor %}
      </body>
      </html>
      
      • 编写blog_detail.html`文件

      别名home需要编写到路由中

      <!DOCTYPE html>
      <html>
      <head>
      	<title>{{ blog.title }}</title>
      </head>
      <body>
      	<a href='{% url "home" %}'>
      		<div>我的博客</div>
      	</a>
      	
      	<h3>{{ blog.title }}</h3>
      	<p>{{ blog.content }}</p>
      </body>
      </html>
      
    • 编写路由

      • 编写总路由mysite urls.py
      from django.contrib import admin
      from django.urls import path,include
      from blog.views import blog_detail,blog_list
      
      urlpatterns = [
          path('', blog_list, name='home'),
          path('admin/', admin.site.urls),
          path('blog/',include('blog.urls'))
      ]
      
      • 新建并编写子路由blog urls.py
      from django.urls import path
      from .views import blog_detail
      
      urlpatterns = [
          path('<int:blog_pk>', blog_detail, name='blog_detail')
      ]
      

    启动服务python manage.py runserver查看效果

    主页效果

    详情页效果

    • 2种方式统计博客数量

      • 第一种方式,修改blog_list.html

      {% empty %}如果数据条数为0才执行,{{ blogs|length }}显示博客总数

      <!DOCTYPE html>
      <html>
      <head>
      	<title>我的博客</title>
      </head>
      <body>
      	{% for blog in blogs %}
      		<a href="{% url 'blog_detail' blog.pk %}">
      			<h3>{{ blog.title }}</h3>
      		</a>
      		<p>{{ blog.content }}</p>
      
      	{% empty %}
      		<p>-- 暂无博客,敬请期待 --</p>
      	{% endfor %}
      	<p>一共有{{ blogs|length }}篇博客</p>
      
      </body>
      </html>
      
      • 第二种方式,使用{{ blogs.counts }}可以得到同样的结果

    • 新建一个长文本博客,让首页列表文章内容截断显示

    未截断前页面

    修改blog_list.html文件用于截断

    {{ blog.content|truncatechars:30 }}将首页显示为30字符,建议大家这里truncatechars改用truncatechars_html,因为truncatechars可能会有因html截取不全导致html错乱问题

    <!DOCTYPE html>
    <html>
    <head>
    	<title>我的博客</title>
    </head>
    <body>
    	{% for blog in blogs %}
    		<a href="{% url 'blog_detail' blog.pk %}">
    			<h3>{{ blog.title }}</h3>
    		</a>
    		<p>{{ blog.content|truncatechars_html:30 }}</p>
    
    	{% empty %}
    		<p>-- 暂无博客,敬请期待 --</p>
    	{% endfor %}
    	<p>一共有{{ blogs|length }}篇博客</p>
    
    
    </body>
    </html>
    
    • 博客详情页添加,作者,发表日期

    blog_detail.html{{blog.created_time|date:"Y-m-d h:m:s"}}过滤器用来展示12小时类型的日期时间。“Y-m-d G:n:s"用来展示24小时类型的日期时间。

    <!DOCTYPE html>
    <html>
    <head>
    	<title>{{ blog.title }}</title>
    </head>
    <body>
    	<a href='{% url "home" %}'>
    		<div>我的博客</div>
    	</a>
    	
    	<h3>{{ blog.title }}</h3>
    	<p>{{ blog.author }}</p>
    	<p>{{ blog.created_time|date:"Y-m-d h:n:s" }}</p>
    	<p>{{ blog.content }}</p>
    </body>
    </html>
    

    进一步优化,给博客详情页加上博客类型

    blog_detail.html增加一个分类

    <!DOCTYPE html>
    <html>
    <head>
    	<title>{{ blog.title }}</title>
    </head>
    <body>
    	<a href='{% url "home" %}'>
    		<div>我的博客</div>
    	</a>
    	
    	<h3>{{ blog.title }}</h3>
    	<p>作者:{{ blog.author }}</p>
    	<p>发表时间:{{ blog.created_time|date:"Y-m-d G:m:s" }}</p>
    	<p>分类:{{ blog.blog_type }}</a>></p>
    	<p>{{ blog.content }}</p>
    </body>
    </html>
    

    现在看博客详情页,如下所示:

    于是产生了新的需求,让古诗词这个标签变得可以点击,点击后跳转到页面可以显示出所有的古诗词列表。这个页面需要添加路由,在views.py内添加处理方法,还需要增加html模板文件用于页面显示。

    修改blog urls.py文件

    from django.urls import path
    from . import views
    
    urlpatterns = [
        path('<int:blog_pk>', views.blog_detail, name='blog_detail'),
        path('type/<int:blog_type_pk>', views.blogs_with_type, name='blogs_with_type')
    ]
    

    修改blog views.py

    from django.shortcuts import render_to_response, get_object_or_404
    from .models import Blog, BlogType
    
    # Create your views here.
    
    def blog_list(request):
        context = {}
        context['blogs'] = Blog.objects.all()
        return render_to_response('blog_list.html', context)
    
    
    def blog_detail(request, blog_pk):
        context = {}
        context['blog'] = get_object_or_404(Blog, pk=blog_pk)
        return render_to_response('blog_detail.html', context)
    
    def blogs_with_type(request, blog_type_pk):
        context = {}
        blog_type = get_object_or_404(BlogType, pk=blog_type_pk)
        context['blogs'] = Blog.object.filter(blog_type=blog_type)
        context['blog_type'] = blog_type
        return render_to_response('blogs_with_type.html', context)
    

    创建templates blogs_with_type.html模板文件,并修改如下:

    <!DOCTYPE html>
    <html>
    <head>
    	<title>{{ blog_type.type_name }}</title>
    </head>
    <body>
    	<div>
    		<a href='{% url "home" %}'>
    			<h3>个人博客网站</h3>
    		</a>
    	</div>
    	<h3>{{ blog_type.type_name }}</h3>
    	{% for blog in blogs %}
    		<a href="{% url 'blog_detail' blog.pk %}">
    			<h3>{{ blog.title }}</h3>
    		</a>
    		<p>{{ blog.content|truncatechars_html:30 }}</p>
    
    	{% empty %}
    		<p>-- 暂无博客,敬请期待 --</p>
    	{% endfor %}
    	<p>一共有{{ blogs|length }}篇博客</p>
    
    
    </body>
    </html>
    

    重新刷新详情页面

    点击散文标签可以看到正常显示了出来。


    拓展:常见的模板标签

    循环:for

    条件:if(可逻辑判断),ifequal,ifnotequal

    链接:url

    模板嵌套:blockextendsinclude

    注释:{# #}

    日期:date

    字数截取:truncatecharstruncatechars_htmltruncatewordstruncatewords_html

    是否信任htmlsafe

    长度:length

  • 相关阅读:
    [GCJ2017R2]Fresh Chocolate
    李耀于NOIP2010集训出的题 Dvalue
    POI ZAW
    POI SZP
    無名(noname)
    幸运序列(lucky)
    [HNOI2001]求正整数
    灰狼呼唤着同胞(brethren)
    神在夏至祭降下了神谕(oracle)
    [bzoj 4237] 稻草人
  • 原文地址:https://www.cnblogs.com/sjfeng1987/p/11375735.html
Copyright © 2011-2022 走看看