使用Django开发网站时,如果不使用模板,那么将会很不合理。因为我们所有的html代码都需要被硬编码到我们的Python代码中。我们新建一个工程,然后再在新建一个应用程序,并在其中的views.py文件中添加如下代码:

 1 #coding=UTF-8
 2 from django.http.response import HttpResponse, Http404
 3 import datetime
 4 
 5 def hours_ahead(request,offset):
 6     try:
 7         offset = int(offset)
 8     except ValueError:
 9         raise Http404()
10     
11     dt = datetime.datetime.now() + datetime.timedelta(hours = offset)   #datedelta()中参数必须是整型
12     html = "<html><body>In %s hour(s),it will be %s.<body/><html/>"%(offset,dt)
13     return HttpResponse(html)

  从上面的代码中就可以看出,我们的HTML代码和我们的Python混合在一起了,这样不仅影响开发速度,也不便于后期维护。下面我会详细介绍django中的模板。模板的作用是要实现将HTML代码和Python代码分开。首先在我们应用程序下面新建一个templates文件夹,之后我们的所有模板都会放在这个文件夹下面,因为django1.6的setting.py文件中没有TEMPLATE_DIRS这个选项,取而代之的是它会默认去寻找template文件夹下面的模板。我们在这个文件夹下面新建一个html。这个html文件中主要是放一些我们页面不会变化或者很少变化的代码,而那些经常变化的代码我们使用{%block%}{%endblock%}进行申明,然后在子页面中可以对这部分代码进行覆盖。base.html代码如下:

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="UTF-8">
 5 <title>{%block title%}{%endblock%}</title>
 6 </head>
 7 <body>
 8     <h1>My helpful timestamp site</h1>
 9     {%block content%}{%endblock%}
10     {%block footer%}
11     <hr>
12     <p>Thanks for visiting my site</p>
13     {%endblock%}
14 </body>
15 </html>

  上面代码中,我们使用模板标签将html的title,content,以及footer进行了占位。然后再新建一个current_datetime.html的页面继承我们的base.html页面,然后对其中的title,content部分进行覆盖,footer部分保留父页面base.html中的代码。代码如下:

1 {%extends "base.html"%}    <!--使用extends继承base.html页面。必须放在第一行-->
2 
3 {%block title%}The current time{%endblock%}<!--定义title代码块中的内容-->
4 
5 {%block content%}    <!--定义content代码块中的内容-->
6 <P>It is now {{current_date}}.</p>
7 {%endblock%}

  这样使用之后,我们访问current_datetime.html页面的时候整体框架是base.html中所定义的,而局部效果回事我们current_datetime.html中所定义的。对于一个网站而言,我们可以定义尽可能多的{%block%},这样我们子页面继承的时候会有较好的扩展性。下面是视图views.py中所定义的函数代码:

 1 from datetime import datetime
 2 from django.shortcuts import render_to_response
 3 # from django.template.loader import get_template
 4 # from django.template.context import Context
 5 # from django.http.response import HttpResponse
 6 
 7 # Create your views here.
 8 # def current_time(request):
 9 #     now = datetime.now()
10 #     t = get_template('current_time.html')
11 #     html = t.render(Context({'current_date':now}))
12 #      
13 #     return HttpResponse(html)
14 
15 def current_time(request):
16     now = datetime.now()
17     return render_to_response('current_datetime.html',{'current_date':now})

  上面的函数返回当前的时间,注释部分和没注释的代码效果是一样的。值得注意的是使用render_to_response函数时,其第一个参数必须是要使用模板的名称。第二个参数是可选的,如果你要给定这个参数,那么这个参数必须是为该模板创建Context时所使用的字典。如果不给定,函数将使用一个空字典。下面是应用程序中urls.py的代码:

1 from django.conf.urls import patterns, url
2 from Second import views
3 
4 urlpatterns = patterns('',
5     url(r'^time/', views.current_time),
6 )

  urls.py是将我们视图views.py中的代码和我们之后访问页面在地址栏中所输入的地址进行绑定。url()中的第一个参数是一个正则表达式,第二个参数是我们要绑定的函数代码。配置好我们应用程序的urls.py之后,我们还需要在我们项目的urls.py中进行配置,具体如下:

1 from django.conf.urls import patterns, include, url
2 
3 urlpatterns = patterns('',
4     url(r'^Second/',include('Second.urls'))
5 )

  在这里我们使用include将我们应用程序Second中的urls引入。并指定我们要访问页面的正则表达式。结合两个urls.py中正则表达式所描述的url,我们之后在访问页面的时候,路径应该是http://localhost:8000/Second/time/。这里端口8000是默认的。我们可以选择我们想要的端口号,但是前提是那个端口号没有被其它应用程序占用。最有我们在项目的setting.py将我们的应用程序进行注册。打开项目的setting.py,在INSTALLED_APPS中将我们应用程序的名字加入。如下:

Python笔记(五)--Django中使用模板

  然后我们启动服务,并访问localhost:8000/Second/time,可以看到下面的效果。Python笔记(五)--Django中使用模板