Django—模板渲染
参考文档:
Django的学习已经丢了很长一段时间了,时值年底,基本工作都差不多了,准备重新捡起来。
学习心得也会有空mark一下!
准备作业:让我们一览 Django 全貌urls.py
网址入口,关联到对应的views.py中的一个函数(或者generic类),访问网址就对应一个函数。
views.py
处理用户发出的请求,从urls.py中对应过来, 通过渲染templates中的网页可以将显示内容,比如登陆后的用户名,用户请求的数据,输出到网页。
models.py
与数据库操作相关,存入或读取数据时用到这个,当然用不到数据库的时候 你可以不使用。
forms.py
表单,用户在浏览器上输入数据提交,对数据的验证工作以及输入框的生成等工作,当然你也可以不使用。
templates 文件夹
views.py 中的函数渲染templates中的Html模板,得到动态内容的网页,当然可以用缓存来提高速度。
admin.py
后台,可以用很少量的代码就拥有一个强大的后台。
settings.py
Django 的设置,配置文件,比如 DEBUG 的开关,静态文件的位置等。
言归正传,本次主要解决的问题是,通过Django框架将数据库里面的字段显示到前台页面上:
- models.py里新建相关表_Author
- views.py提供数据查询及返回相关结果_result
- urls.py指定相关跳转链接
- templates/app/query.html 负责处理views.py的返回值及渲染显示结果
#models.py from django.db import models # Create your models here. class Author(models.Model): name=models.CharField(u'姓名',max_length=50) qq=models.CharField(max_length=10) addr=models.TextField() email=models.EmailField() def __str__(self): return self.name
#views.py from app.models import Author def query(request): #result=Author.objects.all() result=Author.objects.values_list() #返回数据库查询结果(sql:select * from Author ),list类型, assert isinstance(request, HttpRequest) return render( request, 'app/query.html', { 'title':'Query', #将查询结果渲染到app/query.html的变量result中 'result':result, 'year':datetime.now().year, } )
#urls.py import app.views urlpatterns = [ # Examples: url(r'^admin/', admin.site.urls,name='admin'), url(r'^query/', app.views.query,name='query'),
#templates\app\query.html <table class="table table-hover"> #引用bootstrap表格样式 <caption> Result of Query </caption> #遍历循环赋值 {% for i in result %} <tr> {% for j in i %} <td>{{ j }}</td> {% endfor %} </tr> {% endfor %} </table> {% endblock %}
一切ok的话,启动服务器,结果如下:
但是这里有一个问题,我在views.py里面使用的result=Author.objects.values_list() ,是把该表的所有数据都取出来了。如果现在只想取某几个字段的数据(不想要ID字段),目前我的能力有两种方法解决:
1、views.py里面直接查询我想要的字段:
result=Author.objects.values_list('name','qq','addr','email')
结果对比,可以在django shell里面看到:
>>> print (str(Author.objects.values_list().query)) SELECT "app_author"."id", "app_author"."name", "app_author"."qq", "app_author"." addr", "app_author"."email" FROM "app_author" >>> print (str(Author.objects.values_list('name','qq','addr','email').query)) SELECT "app_author"."name", "app_author"."qq", "app_author"."addr", "app_author" ."email" FROM "app_author"
页面显示效果:
2、views.py里查询条件不变,更改urls里的循环条件,即不输出查询结果列表里面第一个数据(ID字段):
(模板里列表索引取值为 i.n,而不是python里面的i[1])
<table class="table table-hover"> <caption> Result of Query </caption> {% for i in result %} <tr> <td>{{ i.1 }}</td> <td>{{ i.2 }}</td> <td>{{ i.3 }}</td> <td>{{ i.4 }}</td> </tr> {% endfor %} </table>
美观一下,加上列标题:
<table class="table table-hover"> <caption> Result of Query </caption> <tr> {#<td> ID </td>#} <td> NAME </td> <td> QQ </td> <td> ADD </td> <td> MAIL </td> </tr> {% for i in result %} <tr> <td>{{ i.1 }}</td> <td>{{ i.2 }}</td> <td>{{ i.3 }}</td> <td>{{ i.4 }}</td> </tr> {% endfor %} </table>
完工!
Tips:
Django 模板查找机制: Django 查找模板的过程是在每个 app 的 templates 文件夹中找(而不只是当前 app 中的代码只在当前的 app 的 templates 文件夹中找)。各个 app 的 templates 形成一个文件夹列表,Django 遍历这个列表,一个个文件夹进行查找,当在某一个文件夹找到的时候就停止,所有的都遍历完了还找不到指定的模板的时候就是 Template Not Found (过程类似于Python找包)。这样设计有利当然也有弊,有利是的地方是一个app可以用另一个app的模板文件,弊是有可能会找错了。所以我们使用的时候在 templates 中建立一个 app 同名的文件夹,这样就好了。
这就需要把每个app中的 templates 文件夹中再建一个 app 的名称,仅和该app相关的模板放在 app/templates/app/ 目录下面