玖叶教程网

前端编程开发入门

django框架 web开发实战课程 day2

2、django框架响应及templates标签

大家好,今天咱们学习django框架web开发的第二节,django框架的响应及templates标签。我们知道任何一个URL请求,都需要网站有响应反馈,这个反馈里面有状态码和响应结果,状态码咱们熟悉的有200请求成功,301资源或网页等被永久转移,404请求的资源或网页不存在,500内部服务器错误

在django里已经有现成的反馈视图函数,咱们只需要根据函数的语法规则,填写需要返回的内容,django框架就会将相应的内容返回到终端用户的浏览器端。好下面咱们分别看一下这个几个视图函数。

视图函数及状态码

1. HttpResponse 请求成功, 200 内容:Web文本,页面,图片等 +++;

2. JsonResponse 请求成功 200 内容:json格式内容

上面这两个属于一次响应,即返回一次后

3. streamingHttpResponse 请求成功 200 内容:以内容流的形式响应

4. FileResponse 请求成功 200 内容:以内容流的形式打开文件 主要用于下载

上面这两个属于流式响应,持续反馈,直至结束。

以上400个都属于成功响应,返回的状态码为200,下面要讲的是属于请求错误的状态码

5. HttpResponseRedirect 重定向 302

6. HttpResponsePermanentRedirect 永久重定向 301

7 HttpResponseNotModified 网页无改动,该类型无任何参数 304

8. HttpResponseBadRequest 不良响应 400

9. HttpResponseForbidden 禁止访问 403

10. HttpResponseNotFound 404错误 404

11. HttpResponseNotAllowed 不被允许 405

12. HttpResponseGone 无 410

13. HttpResponseServerError 服务器错误 500

咱们在正常网站应用开发中,主要是应用状态码为200的视图函数,通过他们把咱们要传递的信息传递给终端用户,下面咱们就看一下,这个函数具体怎么响应?

(1)HttpResponse:

HttpResponse(content , content_type = None , status = 200 , charset = None)

其中 content:拟输入的字符串 ; content_type:MIME格式的放回内容类型 ; status:响应状态码 ; charset:响应的字符

引用方式:from django.http import HttpResponse

举例:

def index(request):

response = HttpResponse()

response.write("

这是首页,请访问这里

") #可忽略

response.write("

标题

")

return response

(2)JsonResponse类

JsonResponse(data)

其中data是字典类型,返回Json数据类型

举例:

def homeproc2(request):

response = JsonResponse( {'key':'value'})

return response

(3) streamingHttpResponse类

streamingHttpResponse(streaming_content) #streaming_content是内容的迭代形式,以内容流的方式响应

StreamingHttpResponse类下载文件实例

def big_file_download(request):

def file_iterator(file_name , chunk_size = 512):

with open(file_name) as f:

while True:

c = f.read(chunk_size)

if c:

yield c

else:

break

fname = 'C:/Users/Administrator/PycharmProjects/PYC_02/cloudms/msgapp/templates/data.txt'

response = StreamingHttpResponse(file_iterator(fname))

return response

(4) FileResponse类

FileResponse(stream) #stream:以流的形式打开后的文件

def homeproc3(request):

cwd = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

response = FileResponse(open(cwd + "/msgapp/templates/chelsea-gray.jpg","rb")) #随便找张图片

response['Content-Type'] = 'application/octet-stream' #用于指定文件类型

response['Content-Disposition'] = 'attachment;filename="chelsea-gray.jpg"' #用于指定下载文件的默认名称

return response

(5)HttpResponseRedirect

- 函数格式 HttpResponseRedirect(url) 返回状态码 302

(6) HttpResponseForbidden、HttpResponseNotFound、HttpResponseServerError

- 直接返回状态码 比如:return HttpResponseForbidden

render

render 一个特殊的HttpResponse方法,他是通过模板和参数字典, 返回一个渲染后的HttpResponse对象。

render方法有六个参数,一是request参数,二是html模板文件名,三是带具体数据的字典参数。

参数:

  • request: 用于生成响应的请求对象
  • template: 要使用的模板的完整名称, 可选的参数
  • context: 添加到模板上下文的一个字典. 默认是一个空字典. 如果字典中的某个值是可调用的, 视图将在渲染模板之前调用它.
  • content_type:  生成的文档要使用的MIME类型. 默认为DEFAULT_CONTENT_TYPE设置的值. 默认为"text/html" 参照对照表
  • status: 响应的状态码. 默认为200
  • useing: 用于加载模板的模板引擎的名称

咱们之前说过,django是mtv模型,真正能实现模板与模型及视数相结合,就是靠render函数,下面咱们具体讲一下render的具体用法。

render函数中的模板 Templates文件夹

- 什么是模板

1. 模板是html页面,可以根据视图中传递的数据填充值相应的页面元素。

-static文件夹

开发中经常说道的静态文件就是:图片,javascript,css等,这些静态文件的访问很简单,就是把文件传送给请求方即可。

在html文件的最上方加上{% load staticfiles %},之后在需要的地方直接调用静态文件就行了。例如:

或者

模板标签

1、判断

{% if %} 标签接受 and , or 或者 not 关键字来对多个变量做判断 ,或者对变量取反( not )

(1)

{% if condition %} ... display {% endif %}

(2)

{% if condition1 %} ... display 1 {% elif condition2 %} ... display 2 {% else %} ... display 3 {% endif %}

(3)多条件

{% if usertype == '业务员' or usertype == '经理' %} ... display 3 {% endif%}

2、循环

例如,咱们返回一个列表list 变量,我们可以使用下面的代码来显示这个列表

<ul> {% for item in list %} <li>{{ item .name }}li> {% endfor %} ul>

反向迭代

{% for item in item reversed %} ... {% endfor %}

嵌套

{% for item in list %} <h1>{{ item .name }}h1> <ul> {% for sport in item .sports_played %} <li>{{ sport }}li> {% endfor %} ul> {% endfor %}

3、ifequal/ifnotequal 标签

比较两个值,当他们相等时,显示在 {% ifequal %} 和 {% endifequal %} 之中所有的值。

{% ifequal user currentuser %} <h1>Welcome!h1> {% endifequal %}

4、注释

{# 这是一个注释 #}

5、过滤器

模板过滤器可以在变量被显示前修改它,过滤器使用管道字符

将my_list中的第一个元素转化为大写

{{ my_list|first|upper }}

只显示bio参数的开始30个元素

{{ bio|truncatewords:"30" }}

6、include标签

{% include %} 标签允许在模板中包含其它的模板的内容。

{% include "nav.html" %}

练习: 1. 127.0.0.1:8000/login : 引入登陆界面模板

2. 127.0.0.1:8000/regedit : 引入注册页面

3. 处理好所有静态文件

4. 测试标签函数的使用

注意点:

1、有些html模板开始包含

导致css文件无法正常打开,而是以下载的形式出现,需要把模板中的这句删除掉,就能正常使用。

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言