Django学习系列—第一天
以前学习过一段时间Django,对比了另一个python web框架flask,相对于flask框架,Django框架更加的集大成,学习一段时间就会忘记,于是再次记录该Django的学习过程,以便将来的学习需要。
我直接从第一个网站开始,至于python、Django 的安装,我就不多说了。使用的开发环境为pycharm。
新建一个mysite的Django的工程,一个名为book的app。
如下:
当你看到这个页面的时候,说明第一个Django程序已经运行。下面我们来向里面添加所需要的功能。
视图和URL配置
首先我们先看第一步运行Hello,world!。打开view.py,添加如下的代码:
def hello():
return HttpResponse('Hello World')
到此,第一个页面还没有完成,因为我们需要URL映射,从urls.py找到第一个页面的地址,所以需要进行下面的配置:
urlpatterns = [
url(r'^admin/', include(admin.site.urls)),
url(r'^hello/', hello),
]
这样就可以运行了,会显示hello world的页面。
这里使用了正则匹配原则。再来温习一下:
我们来分析一下整个流程:
- 进来的请求转入/hello/.
- Django通过在ROOT_URLCONF配置来决定根URLconf.
- Django在URLconf中的所有URL模式中,查找第一个匹配/hello/的条目。
- 如果找到匹配,将调用相应的视图函数
- 视图函数返回一个HttpResponse
- Django转换HttpResponse为一个适合的HTTP response, 以Web page显示出来
动态内容
上面我们只是实现了简单的静态页面,但实际工作中会有很多的动态页面,我们来实现一下动态页面的学习。我们就用页面显示当前时间。
def current_datetime(request):
now = datetime.datetime.now()
html = "<html><head></head><body><h1>%s</h1></body></html>" % now
return HttpResponse(html)
同样的道理在urls.py中做映射。
动态内容–添加时间差
在实际开发中,有的页面需要添加参数,我们就实现一个时间差的页面。代码如下:
def hours_ahead(request,offest):
try:
offest = int(offest)
except ValueError:
raise Http404()
dt = datetime.datetime.now() + datetime.timedelta(hours=offest)
return HttpResponse(dt)
urls.py设置如下:
url(r'^time/plus/(\d{1,2})/$', hours_ahead),
这样就实现了页面修改操作。
模板引擎
Django之所以强大,与他的强大的模板引擎是分不开的。
在前面的例子中,你可能已经注意到我们在例子视图中返回文本的方式有点特别。 也就是说,HTML被直接硬编码在 Python 代码之中。
如果出现大量的编码,这也许不是一个好主意。
在刚才的页面中,我们使用模板来实现,新建一个html文件在templates文件夹中。代码如下:
<html><body>It is now {{ current_date }}.</body></html>
打开views.py:
def current_datetime2(request):
now = datetime.datetime.now()
return render_to_response('current_datetime.html', {'current_date':now})
这样就实现了模板的功能。
除了这样,我们可以使用local()技巧。只要在html页面的变量与views中传过去的变量名一样就可以了。
模板继承
实际开发中,会有大量的重复代码,比如一个网站,其他的次网站中的上面与下面尾部应该都是一样的。
定义基础模板
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>{% block title %}{% endblock %}</title>
</head>
<body>
<h1>My Site</h1>
{% block content %}{% endblock %}
{% block footer %}
<hr>
<p>Thank you for visting my site.</p>
{% endblock %}
</body>
</html>
在页面中继承模板:
{% extends "base.html" %}
{% block title %}The current time{% endblock %}
{% block content %}
<h1>It is now {{ now }}.</h1>
{% endblock %}
这样就完成了模板的继承。
明天继续,完成下面的数据库操作。