Django—模板渲染

参考文档:

http://www.cnblogs.com/fnng/p/4373108.html

https://code.ziqiangxuetang.com/django/django-intro.html

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框架将数据库里面的字段显示到前台页面上:

  1. models.py里新建相关表_Author
  2. views.py提供数据查询及返回相关结果_result
  3. urls.py指定相关跳转链接
  4. 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的话,启动服务器,结果如下:

2018-01-16_185401

但是这里有一个问题,我在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"

页面显示效果:

2018-01-16_190656

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>

页面显示效果:2018-01-16_191227

美观一下,加上列标题:

<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>

2018-01-16_191637

完工!

 

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/ 目录下面

posted @ 2018-01-16 19:20  Eric_Young  阅读(3121)  评论(0编辑  收藏  举报