1、概述
本篇主要在之前Django使用的基础上,详细讲述request中的GET方法。并简单实现对网页上文章的分类功能。
2、打印查看request的请求方法
1)view.py的打印示例代码
def index(request):
print(request)
print('==='*3)
print(dir(request))
print('==='*3)
print(type(request))
print('==='*3)
print(request.GET)
print('==='*3)
queryset = request.GET.get('tag')
print(queryset)
说明:首先打印request本身,再打印request的属性和方法,接着打印request的类型,然后打印request的GET属性,最后打印出GET属性中的值。
2)当在网页中输入http://127.0.0.1:8000/index(访问自身搭建的网站)
打印结果如下:
解析:
a、方法1输出的是request的请求方式(此处是GET方式)和网址后面的地址“/index”;
b、方法2输出的是request的内置属性和方法;
c、方法3输出是request的类型是WSGIRequest;
d、方法4和方法5输出为空。
3)当在网页中输入http://127.0.0.1:8000/index?tag=life(访问自身搭建的网站)
打印结果如下:
解析:
a、与上面打印结果对比可知,方法1输出多了网址增加部分;
b、方法2与方法3输出上述一致;
c、方法4输出了字典类型对象,即网址中问号?后面的内容;
d、方法5取出了字典中的值;
3、实现文章分类功能
有2中的request原理可知,可以通过网址中增加相关属性,最终于数据库内容结合来判断网页的显示内容。
1)在model.py层中为Article添加类型选项,以便区别文章。
class Article(models.Model):
headline = models.CharField(null=True, blank=True, max_length=500)
content = models.TextField(null=True, blank=True)
TAG_CHOICES = (
('life', 'Life'),
('tech', 'Tech')
)
tag = models.CharField(null=True,blank=True,max_length=50,choices=TAG_CHOICES)
def __str__(self):
return self.headline
解析:
a、添加了一个TAG_CHOICES的一个元组类型,元组中包含两个元组对象(名称,显示名称);
b、在数据库中创建tag字段,可以选择文章类型,具体Django后台操作如下:
2)在view.py层中实现文章分类
def index(request):
context = {}
queryset = request.GET.get('tag')
if queryset:
article_list = Article.objects.filter(tag=queryset)
else:
article_list = Article.objects.all()
context['article_list'] = article_list
return render(request, 'first_web.html', context)
解析:
a、使用判别语句来输出不同数据库数据,当queryset存在时,使用Article数据过滤方法输出;
b、当queryset为空时,则输出所有文章。
3)修改模板层html代码
<div class="ui simple dropdown item">
Categories
<i class="dropdown icon"></i>
<div class="menu">
<a class="item" href="?tag=life">life</a>
<a class="item" href="?tag=tech">tech</a>
</div>
</div>
说明:
a、在life和tech的下拉菜单中添加链接href="?tag=life"和href="?tag=tech";
b、当在网页中点击life或tech对象时,网址中就会出现访问地址,同时request的GET方法就会见效。