文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
HttpResponse 对象
HttpResponse对象
- 视图在接收请求并处理后,必须返回HttpResponse对象或子对象
- 在django.http模块中定义了HttpResponse对象的API
- HttpRequest对象由Django创建,HttpResponse对象由开发人员创建
- 运行服务器,在浏览器中浏览首页,可以在浏览器“开发者工具”中看到响应信息如下图
- 标号3为响应头信息,点击标号4处可以查看响应体信息
属性
- content:表示返回的内容
- charset:表示response采用的编码字符集,默认为utf-8
- status_code:返回的HTTP响应状态码
- content-type:指定返回数据的的MIME类型,默认为'text/html'
方法
- init:创建HttpResponse对象后完成返回内容的初始化
- set_cookie:设置Cookie信息
- write:向响应体中写数据
- cookie是网站以键值对格式存储在浏览器中的一段纯文本信息,用于实现用户跟踪
- expires是以秒为单位的整数,会话将在当前时间+指定秒后的时间过期
- 如果不指定过期时间,则关闭浏览器过期
set_cookie(key, value='', expires=None)
- delete_cookie(key):删除指定的key的Cookie,如果key不存在则什么也不发生
示例
直接返回数据
- 打开booktest/views.py文件,定义视图index2如下
def index2(request):
str='<h1>hello world</h1>'
return HttpResponse(str)
- 打开booktest/urls.py文件,配置url
url(r'^index2/$',views.index2),
- 运行服务器,在浏览器中打开如下网址
http://127.0.0.1:8000/index2/
- 运行效果如下图
- 如果使用这种方式构造一个漂亮丰富的页面,对于开发人员真是会发疯,于是就有了下面的方式
调用模板
- 可以将html、css、js定义到一个html文件中,然后由视图来调用
- 打开booktest/views.py文件,定义视图index3如下
from django.template import RequestContext, loader
...
def index3(request):
#加载模板
t1=loader.get_template('booktest/index3.html')
#构造上下文
context=RequestContext(request,{'h1':'hello'})
#使用上下文渲染模板,生成字符串后返回响应对象
return HttpResponse(t1.render(context))
- 打开booktest/urls.py文件,配置url
url(r'^index3/$',views.index3),
- 在templates/booktest/目录下创建index3.html,代码如下
<html>
<head>
<title>使用模板</title>
</head>
<body>
<h1>{{h1}}</h1>
</body>
</html>
- 运行服务器,在浏览器中打开如下网址
http://127.0.0.1:8000/index3/
- 运行效果如下图
调用模板简写函数render
每次调用模板时都要执行加载、上下文、渲染三个步骤,为了简化操作,Django定义了render()函数封装了以上三个步骤的代码,定义在django.shortcuts模块中
打开booktest/views.py文件,定义视图index3如下
from django.shortcuts import render
...
def index3(request):
return render(request, 'booktest/index3.html', {'h1': 'hello'})
- 是不是用render()函数调用模板比上面简单多了?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论