Django框架(五)---- app组件

Django框架(五)


 App组件:

我们使用:python manage.py startapp app-name 命令创建app,可得到如下结构的目录: 

1 appname
2  |___migrations
3  |     |_ __init__.py
4  |_ __init__.py
5  |_ admin.py
6  |_ apps.py
7  |_ models.py
8  |_ tests.py
9  |_ views.py

 


 

一、models.py:模型层

  在models.py文件中,需要去创建你的模型类,继承自models.Model类,包含了Django和数据库之间数据的基本字段和行为,每个模型类映射到数据库形成一张数据表,例如:

1 from django.db import models
2 
3 class Users(models.Model):
4     name = models.CharField(max_length=32)
5     age = models.IntegerField(default=20)
6     phone = models.CharField(max_length=16)

  在上述例子中,定义了一个Users类,类中包含三个对象,这三个对象名映射到数据库表,为表的字段名;后面定义了这三个对象的数据类型Field以及限定。

   Field字段类型通常常用的有:1、CharField:字符串,必须有参数 max_length规定长度;

               2、IntegerField:整数;

               3、FileField:文件上传字段;

               还有很多,具体可查阅Django-1.10中文文档/filed

  在建立了空数据库,并且在settings.py中设置好DATABASES,然后创建好需要的model类,即可使用命令:

1 python manage.py makemigrations
2 python manage.py migrate

  来让Django生成数据库表,得到:

    (图片为MySQL数据库表)

 

  但是:一般是首先创建数据库表,需要的字段,属性,主键等都设置完全后,再创建model类,因为Django自动生成的数据表,其中属性有些不尽人意。

  一般表的名称是  appname_表名,如果是外来导入的数据表,则可以使用代码,指定真实表名:

1 class Districts(models.Model):
2     name = models.CharField(max_length=270, default='NULL')
3     parent_id = models.IntegerField(max_length=5, default='NULL')
4     order = models.IntegerField(max_length=2, default='NULL')
5 
6     class Meta:
7         db_table = 'district'  # 指定真实表名

 

 

 

 


 

二、urls.py:子路由

  将project/urls.py文件复制一份到app目录下;

  在其中书写规则,分析从总路由project/urls.py分配过来的关于该app的请求,然后推送给相应的视图层函数,进行处理并返回一个响应;

  例子:

1 from django.conf.urls import url
2 
3 from . import views
4 
5 urlpatterns = [
6     url(r'^$', views.index, name='index'),
7 ]

 

  1、首先导入视图文件:views.py

  2、因为是总路由分配过来的请求,则这些请求的URL,前面必定是:IP:PORT/appname 结构

  3、url()函数第一个参数:正则表达式,根据请求URL的appname后面的结构进行匹配;

         第二个参数:代表匹配成功后,触发views模块中的index函数;

           第三个参数:命名,涉及到后面的模板层,省事;

  4、有多少视图层操作,就写多少个url函数;


 

三、views.py:视图层

  views.py文件,接收Web请求并且返回Web响应,这个响应可以是HTML内容,重定向或404,甚至是其他东西;

  直接上例子:

1 from django.http import HttpResponse
2  
3 def index(request):4 
4 return HttpResponse("Hello World! ")

   1、导入django.http模块的HttpResponse函数;

    每写成的视图函数都负责实例化,需要填充并且返回一个函数;

      可返回:HttpResponse:返回一段内容,如上述例子的字符串等等,status=200

          HttpResponseNotFound:返回未找到网页错误,status=404

          Http404:也可以实现HttpResponseNotFound的效果

          HttpResponse(status=404):可以设置status值,实现404效果

          等等等等。。。。

    可查看Django-1.10中文文档--请求与响应中的响应函数

   2、编写函数index,返回一个"Hello World! "的响应;

   3、这是最简单的一个视图,按照之前设置好的app/urls.py子路由文件,运行Django服务,浏览器 IP:PORT/appname 即可显示"Hello World! "

 


 

 四、templates:模板层

  实际应用过程中,Django服务根据请求调取数据库数据,处理数据并且返回相应的HTML,因此需要动态的创建HTML文件,将处理后的数据填充其中,响应在浏览器;

  模板包含一部分所需HTML输出的静态部分,以及一部分描述如何插入动态内容的特殊语法;

  因此,需要在与manage.py同一级的目录中创建一个templates目录,在templates目录中,每个app创建以app-name命名的文件夹,在app-name文件夹内,放置该app使用到的模板HTML文件

  变量:写法:{{ 变量名 }}

     要求:变量名由字母数字字符和下划线(' _ ')任意组合,不能有空格或者标点符号

     方法:使用点(' . ')来访问变量的属性,如 {{ variable.id }} 访问id属性

  过滤器:写法:{{ 变量名|条件 }}

         可以参看Django-1.10中文文档-内置过滤器共60多个

  标签:写法:{% tag %}

        一些标签还需要结束标签,{% tag %} 。。。{% endtag %}

        可以参看Django-1.10中文文档-内置标签引用

     常用标签:1、for标签:

            例子:

1 {% for v in user_list %}
2     <tr>
3         <td>{{ v.id }}</td>
4         <td>{{ v.name }}</td>
5         <td>{{ v.age }}</td>
6         <td>{{ v.phone }}</td>
7     </tr>
8{% endfor %}

             2、if,elif,else标签:

1 {% if athlete_list %}
2     Number of athletes: {{ athlete_list|length }}
3 {% elif athlete_in_locker_room_list %}
4     Athletes should be out of the locker room soon!
5 {% else %}
6     No athletes.
7 {% endif %}

  注释:写法:{#   #}   中间的值不会显示

  模板继承:待定 

  

  

 

 

 

 

posted @ 2018-06-13 09:42  风缘  阅读(298)  评论(0)    收藏  举报