django学习04---模板的渲染

来源:互联网 发布:定制衣柜 知乎 编辑:程序博客网 时间:2024/06/07 05:43

  在上一章节中我们使用 django.http.HttpResponse() 来输出 “Hello python!”。该方式将数据与视图混合在一起,不符合 Django 的 MTV 思想。
  本次将详细介绍 Django 模板的应用,模板是一个文本,用于分离文档的表现形式和内容。

一、渲染初步认识

1、Views.py的作用?

  • 执行业务逻辑
  • 渲染网页(通常使用模板)
  • 通过模型model访问数据库

2、模板是什么?

模型,模具,模板?

  • Django的模板(template)是一种带有专门语法(DTL)的HTML文件。
  • DTL:
  • Django Template Language

3、模板的渲染

  • 什么是渲染?
  • 渲染在电脑绘图中是指用软件从模型生成图像的过程.
  • 模板的渲染是指利用模板模型与上下文数据生成response的HTML页面。

二、示例

1、渲染的几种方式

(1)HttpResponse, Template, Context

(2)HttpResponse, get_template

(3)HttpResponse, render_to_string

(4)Render_to_response

(5)render

常用的一般是第四和第五种,因为第四和第五种是代码量最少的,前三种在以前的版本中也有使用。

2、实例演示

首先创建一个项目

step1 创建目录并修改settings.py文件

django-admin.py startproject tmpshow  #创建tmpshow项目cd tmpshow  #进入目录中python manage.py startapp books  #创建apptree  #查看目录结构

这里写图片描述

vim tmpshow/settings.py  #修改setting.py文件#在settings.py中添加'books' appINSTALLED_APPS = [    'django.contrib.admin',    'django.contrib.auth',    'django.contrib.contenttypes',    'django.contrib.sessions',    'django.contrib.messages',    'django.contrib.staticfiles',    'books'  #添加app]

url.py文件代码

vim tmpshow/urls.pyfrom django.conf.urls import urlfrom django.contrib import adminfrom books import viewsurlpatterns = [    url(r'^admin/', admin.site.urls),    url(r'^books/([\S\s]*)/$', views.hello_books) #这里使用了正则在上一次中有讲过,如果还不懂可以看一下django学习03]

(1)HttpResponse, Template, Context

vim books/views.py #修改views.pyfrom django.http import HttpResponsefrom django.template import Template, Contextdef hello_books(request, bn): #step 1 生成模板对象    t = Template(u'<html><body> 欢迎浏览 {{books_name}} </body></html>')#step2 生成上下文对象    c = Context({'books_name':bn})#step3 渲染    html =  t.render(c)#step4 回应    return HttpResponse(html)

运行程序

python manage.py runserver

地址栏写下图,如果是这个效果则表示成功
这里写图片描述


(2)HttpResponse, get_template

vim books/views.py #修改views.pyfrom django.http import HttpResponsefrom django.template import Template, Contextfrom django.template.loader import get_templatedef hello_books(request, bn):    t = get_template('hello_books.html') #此处得到的t的模板对象render方法,需要传递一个字典参数    html = t.render({"books_name":bn})    return HttpResponse(html)

创建 hello_books.html文件

mkdir books/templates  #创建模板文件夹vim books/templates/hello_books.html  #创建html文件

hello_books.html内容

<html>    <body>        <h1>欢迎浏览  {{books_name}}</h1>    </body></html>

运行程序

python manage.py runserver

地址栏写下图,如果是这个效果则表示成功
这里写图片描述


(3)HttpResponse, render_to_string

vim books/views.py #修改views.pyfrom django.http import HttpResponsefrom django.template.loader import render_to_stringdef hello_books(request, bn):    html = render_to_string('welcome.html')    return HttpResponse(html)

创建 welcome.html文件

vim books/templates/welcome.html  #创建html文件

welcome.html内容

<html>    <body>        <h1>欢迎浏览 来到冰棒博客!</h1>    </body></html>

运行程序

python manage.py runserver

地址栏写下图,如果是这个效果则表示成功
这里写图片描述


(4)Render_to_response

vim books/views.py #修改views.pyfrom django.shortcuts import render_to_responsedef hello_books(request, bn):    return render_to_response('hello_books.html',{"books_name":bn}) 

hello_books.html内容沿用上的内容

运行程序

python manage.py runserver

地址栏写下图,如果是这个效果则表示成功
这里写图片描述


(5)render

vim books/views.py #修改views.pyfrom django.shortcuts import renderdef hello_books(request, bn):    return render(request,'hello_books.html',{"books_name":bn}) 

hello_books.html内容沿用上的内容

运行程序

python manage.py runserver

地址栏写下图,如果是这个效果则表示成功
这里写图片描述

三、总结

  可以看出代码最简洁的是第四和第五种方法,将那么长的代码整整缩短到只有一行,用起来还是很爽的,以后最常用的则为后面两种。
  前面的3种方法也是需要掌握一下的,因为在一些企业中用的低版本的django,可能暂时还有render的模块。

原创粉丝点击