以下是关于“对Django视图(views)和模版(templates)的使用详解”的完整攻略:
Django视图(Views)是与请求(requests)相关联的Python函数或方法,它们接收HTTP请求并以HTTP响应形式返回。Django模版(Templates)则是用来渲染数据的HTML文件,其中包含静态和动态的内容,在模板中可以插入数据,控制结构,过滤器等,并使Web应用程序返回动态内容更加轻松。
要将视图和模版添加到Django应用程序中,请按以下步骤操作:
首先,在终端中输入以下命令创建一个名为testapp的Django应用程序:
django-admin.py startproject testapp
接下来,在testapp目录中创建一个名为views.py的Python文件,其中包含以下示例视图的代码。这个示例视图将返回一个HTML响应,其中包含一个表示当前日期和时间的字符串:
from django.http import HttpResponse
import datetime
def current_datetime(request):
now = datetime.datetime.now()
html = "<html><body>It is now %s.</body></html>" % now
return HttpResponse(html)
在这个视图函数中,引入了Django的HttpResponse类和当前时间。之后生成一个包含HTML标签和当前时间的字符串,并作为HttpResponse返回。
接下来,在testapp目录中创建一个名为templates的文件夹,并在其中创建名为base.html的HTML模版文件。base.html文件包含一些公共页面元素,例如页眉和页脚,并可用于所有其他模版文件中。
在base.html文件中添加以下代码:
<!DOCTYPE html>
<html>
<head>
<title>Django Template Example</title>
</head>
<body>
<header>
<h1>Django Template Example</h1>
</header>
<main>
{% block content %}
{% endblock %}
</main>
<footer>
<p> Copyright © {% now "Y" %}
</footer>
</body>
</html>
在此模板中,分别定义了{% block content %}和{% endblock %},代表需要添加动态内容的点位。这些点位将在后续的视图函数中填充。
现在,让我们创建一个指定日期和时间的视图,并使用模板来呈现数据。
接下来,在testapp目录中创建名为mytemplate.html的HTML模版文件(继承了base.html),并添加以下代码:
{% extends "base.html" %}
{% block content %}
<h2>Current Time and Date</h2>
<p>Current date and time: {{ date }}</p>
{% endblock %}
在这个模板中,使用了基本的HTML标记,以及模板引擎的语法(使用了{{ }}语句,来表示要使用视图函数中传入的数据)。
最后,在视图函数中,渲染mytemplate.html模板,并传入current_date变量:
from django.shortcuts import render
import datetime
def mytemplate(request):
current_date = datetime.datetime.now()
return render(request, 'mytemplate.html', {'date': current_date})
在这个视图函数中,引入了Django的render()函数,作为HttpResponse返回一个已渲染的模板,并通过params类传递了当前的日期时间参数。
在本文中,我们简要讲解了如何使用Django视图和模板,并赋予你了一个深入学习的起点,展示了通过使用Django框架及其组件来创建Web应用程序的方法。希望你喜欢这篇文章并成功地创建自己的Django应用程序。
本文链接:http://task.lmcjl.com/news/15681.html