blog post list.html,Django学习(四)

欢迎关注我的公众号:zx94_11

生成列表和视图

博客列表

博客详情

导包

from django.shortcuts import render, get_object_or_404

from .models import Post

博客列表

def post_list(request):

posts = Post.published.all()

return render(request,

'blog/post/list.html',

{'posts': posts})

博客详情

def post_detail(request, year, month, day, post):

post = get_object_or_404(Post,

slug=post,

status='published',

publish__year=year,

publish__month=month,

publish__day=day)

return render(request,

'blog/post/detail.html',

{'post': post})

添加URL路径

打开blog/urls.py写入

from django.urls import path

from . import views

app_name = 'blog'

urlpatterns = [

path('', views.post_list, name='post_list'),

path('',

views.post_detail, name='post_detail')

]

在mysite/urls.py加上:

from django.contrib import admin

from django.urls import path, include

urlpatterns = [

path('admin/', admin.site.urls),

path('blog/', include('blog.urls', namespace='blog')),

]

模型的标准URL

由于post_detail的URL比较特别,所以在blog/models.py中添加特殊的处理

from django.urls import reverse

class Post(models.Model):

...

def get_absolute_url(self):

return reverse('blog:post_detail', args=[self.publish.year,

self.publish.month,

self.publish.day,

self.slug])

视图模版

9538342715ca

文件结构

base.html

{% load static %}

{% block title %}{% endblock %}

{% block content %}

{% endblock %}

detail.html

{% extends 'blog/base.html' %}

{% block title %}

{{ post.title }}

{% endblock %}

{% block content %}

{{ post.title }}

Published {{ post.publish }} by {{ post.author }}

{{ post.body|linebreaks }}

{% endblock %}

list.html

{% extends 'blog/base.html' %}

{% block title %}

My blog

{% endblock %}

{% block content %}

My Blog

{% for post in posts %}

{{ post.title }}

Published {{ post.publish }} by {{ post.author }}

{#truncatewords:将数值截取至指定的单词数量#}

{#linebreaks:将输出结果转换为HTML换行符#}

{{ post.body|truncatewords:30|linebreaks }}

{% endfor %}

{% endblock %}

blog.css

body {

margin: 0;

padding: 0;

font-family: helvetica, sans-serif;

}

a {

color: #00abff;

text-decoration: none;

}

h1 {

font-weight: normal;

border-bottom: 1px solid #bbb;

padding: 0 0 10px 0;

}

h2 {

font-weight: normal;

margin: 30px 0 0;

}

#content {

float: left;

width: 60%;

padding: 0 0 0 30px;

}

#sidebar {

float: right;

width: 30%;

padding: 10px;

background: #efefef;

height: 100%;

}

p.date {

color: #ccc;

font-family: georgia, serif;

font-size: 12px;

font-style: italic;

}

.paginator {

margin: 40px 0;

font-weight: bold;

}

label {

float: left;

clear: both;

color: #333;

margin-bottom: 4px;

}

input, textarea {

clear: both;

float: left;

margin: 0 0 10px;

background: #ededed;

border: 0;

padding: 6px 10px;

font-size: 12px;

}

input[type=submit] {

font-weight: bold;

background: #00abff;

color: #fff;

padding: 10px 20px;

font-size: 14px;

text-transform: uppercase;

}

.errorlist {

color: #cc0033;

float: left;

clear: both;

padding-left: 10px;

}

.comment {

padding: 10px;

}

.comment:nth-child(even) {

background: #efefef;

}

.comment .info {

font-weight: bold;

font-size: 12px;

color: #666;

}

结果展示

9538342715ca

列表页

9538342715ca

详情页

添加分页机制

修改blog/views.py的post_list

paginator = Paginator(object_list, 1)里面的数字决定一页里面有几条数据,为了展示效果,先改为1

from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger

def post_list(request):

object_list = Post.published.all()

paginator = Paginator(object_list, 1)

page = request.GET.get('page')

try:

posts = paginator.page(page)

except PageNotAnInteger:

# 如果「不是数字」则去第一页

posts = paginator.page(1)

except EmptyPage:

# 如果「页数太大」就去最后一页

posts = paginator.page(paginator.num_pages)

return render(request,

'blog/post/list.html',

{'posts': posts, 'page': page})

增加一个blog/templates/pagination.html

{% if page.has_previous %}

Previous

{% endif %}

Page {{ page.number }} of {{ page.paginator.num_pages }}.

{% if page.has_next %}

Next

{% endif %}

在blog/templates/blog/post/list.html最后面添加

...

{% include "pagination.html" with page=posts %}

{% endblock %}

9538342715ca

效果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
django中的request.body和request.POST是用来获取HTTP请求中的数据的两种方式。 request.body是一个字符串,它包含了HTTP请求的主体部分。当请求的Content-Type为application/json或multipart/form-data等格式时,request.POST无法获取到数据,只能通过request.body来获取原始数据。需要注意的是,当请求的Content-Type为application/x-www-form-urlencoded时,request.POST可以获取到数据。 request.POST是一个字典对象,它包含了通过POST方法提交的表单数据。当请求的Content-Type为application/x-www-form-urlencoded时,request.POST可以获取到表单数据。但是需要注意的是,当表单中有多个相同的字段名时,request.POST只会获取到最后一个字段的值。如果需要获取所有相同字段名的值,可以使用request.POST.getlist('field_name')方法来获取一个列表,但是需要注意列表中的元素都是字符串,如果需要转换类型,需要自行处理。\[1\]\[2\] 总结一下,当请求的Content-Type为application/json或multipart/form-data等格式时,可以使用request.body来获取原始数据;当请求的Content-Type为application/x-www-form-urlencoded时,可以使用request.POST来获取表单数据。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [django request.body、request.POST、request.data](https://blog.csdn.net/weixin_42752248/article/details/113884907)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [关于ajax post 数据时django中request.body与request.POST问题](https://blog.csdn.net/weixin_30632267/article/details/112881805)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Django request.POST 、 request.body 、request.data使用](https://blog.csdn.net/bocai_xiaodaidai/article/details/113257842)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值