Django学习系列—第一天

Django学习系列—第一天

  以前学习过一段时间Django,对比了另一个python web框架flask,相对于flask框架,Django框架更加的集大成,学习一段时间就会忘记,于是再次记录该Django的学习过程,以便将来的学习需要。

我直接从第一个网站开始,至于python、Django 的安装,我就不多说了。使用的开发环境为pycharm。

新建一个mysite的Django的工程,一个名为book的app。

如下:

Django学习系列—第一天_第1张图片

Django学习系列—第一天_第2张图片

当你看到这个页面的时候,说明第一个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的页面。

这里使用了正则匹配原则。再来温习一下:

Django学习系列—第一天_第3张图片

我们来分析一下整个流程:

  1. 进来的请求转入/hello/.
  2. Django通过在ROOT_URLCONF配置来决定根URLconf.
  3. Django在URLconf中的所有URL模式中,查找第一个匹配/hello/的条目。
  4. 如果找到匹配,将调用相应的视图函数
  5. 视图函数返回一个HttpResponse
  6. 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 %}

这样就完成了模板的继承。
明天继续,完成下面的数据库操作。

你可能感兴趣的:(Django学习系列—第一天)