过滤器跟标签一个样,也是在模板中对函数进行调用,它可对输出变量的内容的进一步处理(过滤),如对上一节输出的日期进行格式化处理,如对含有大小写的英语单词,全部转换为大写等。
在内置过滤器满足不了需求的情况下,也可进行自定义。自定义步骤跟标签是一致的,也新建templatetags包和文件,然后在模板中进行引入,引入方法也是一样的。
不同的是在py文件中,用的装饰器是@register.filter,在模板中的用法是{{变量名称|过滤器}}。
13.1 常用过滤器一览表
13.2 模板御用
为了加快模板功能的开发,Django专门为template提供了一系列API,在views.py应用时,主要引入from django.shortcuts import render这个模块。调整views.py的index函数如下。
from django.shortcuts import render# 访问数据def index(request): posts = Post.objects.all() return render(request, 'base/index.html', {'posts': posts})
光简化返回内容还不够,错误处理也需要妥善安排才行。为了跟update函数进行比较,在它之后,新建一个detail函数。
from django.shortcuts import render, get_object_or_404# 详细信息def detail(request, post_id): post = get_object_or_404(Post, pk=post_id) return render(request, 'base/detail.html', {'post': post})
在base/urls.py里的末尾,新增detail函数的url配置。
path('detail//', views.detail, name='detail'),
在base/templates/base下,新建detail.py文件,输入内容如下。日期是中文的,可以通过date过滤器,进行格式化处理。
通过http://127.0.0.1:8000/base/detail/10/ 进行访问,id号用一个存在的和一个不存在的,分别测试看看。
岗位详细内容
岗位名称 | 创建日期 |
---|---|
{{ post.name }} | {{ post.createDate | date:'Y-n-d H:i' }} |
如果要查看每个存在岗位的详细信息,可在index.html里,补上链接到detail函数的内容,详情请见下一节。