本篇主要介绍了Django的App及各模块功能、配置情况,具体的各种语法及函数,后面有空会分篇记录
我们当然可以像上篇文章中的Hello World一样,在Django的主模块中加各种功能,但当项目变得巨大的时候,各种各样的功能全都放在这里,就会显得太过杂乱,缺乏逻辑性和层次性。
Django中App的作用就在于此,我们可以将不同类型的功能分成多个不同的App应用来开发,就如同手机上不同的App有不同的功能一样,由手机系A统分别对其使用。
一、App创建和配置
创建App只需要在命令行输入命令:
该命令没有任何返回信息,但执行完后会在项目列表出现一个新的子app文件夹,python manage.py startapp loginworld
二、路由设置(urls)
-
路由规则
- urlpatterns中的元素按照书写顺序从上往下逐一匹配正则表达式,一旦匹配成功则不再继续。
- 当浏览器访问请求的url不是以/结尾时,jango会自动给该请求加/结尾,并让浏览器重新访问.可设置为不主动加结尾处的/,方法:在settings.py文件中加入APPEND_SLASH=False即可,配置文件中虽然没有这个参数,但默认结果是True;当配置完成后url请求后不加/时是访问不到页面的。
- URLconf匹配的位置: URLconf 在请求的URL 上查找,将它当做一个普通的Python 字符串,会取 网址之后?号之前的字符串来做正则匹配. 且匹配出来的所有东西都是字符串形式。
分发思路
把本该在项目目录下的urls.py中进行路由匹配的功能给分发到各个不同的App内,在其中新建urls.py文件来进行路由匹配;在项目目录下的urls.py中建立分发指引路径-
主路由
主路由或者说全局路由通过setting中的ROOT_URLCONF确定,默认为Django文件夹下的urls,
同理推广,我们也可以在子app上再加下级路由连到其他app或别的地方,由此设计出更复杂的多级路由
-
子路由
在设置路由时,可以在path使用name参数为其命名,这样就可以在views页面和html页面通过该名字反向获取URL使用路由
新建的子App默认是没有urls的,我们需要在App目录下新建一个urls.py文件作为子路由,在此处匹配该App对应的各种功能
项目中存在多个App,且App内功能有重复命名时:
比较简单的做法是在每个App的urls页面分别设置一个不同的app_name
,如
#app1.urls.py
app_name = 'app1'
#app2.urls.py
app_name = 'app2'
即可在views和html中准确使用路由:
reverse('app01:hello')
reverse('app02:hello')
{% url 'app02:hello' %}
如果要实现代码的复用,或者了解app_name和namespace的区别可以参考https://www.jianshu.com/p/404500a0408a
三、视图(views)
简单地说就是一个函数,接收并处理请求,调用模型和模版,响应请求
至于详细的,不要急,慢慢来
四、模型(models)
Django模型涉及数据库相关操作,此处以mysql为例
如果没有装mysql 驱动,可以执行以下命令安装:
pip install mysqlclient
如果结合xampp和Navicat两个软件使用,可以更方便地查看数据库信息。
- 数据库配置
对于不同的数据库均需要有不同的配置,但都是在setting中的DATABASES进行,mysql的配置方法如下
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': '此处为项目名称',
'USER': '此处为数据库用户名',
'PASSWORD': '此处为数据用户密码',
'HOST':'此处为本机ip',
'PORT':'此处为数据库使用端口',
}
}
在进行下面的步骤前,最好先在mysql中建立相对应的数据库,使用上面设置的USER名字。
- 模型定义
Django规定,如果要使用模型,必须要创建一个App。
在App目录的models中可按如下方法建表:
# models.py
from django.db import models
class Test(models.Model):
user = models.CharField(max_length=20)
password = models.CharField(max_length=200)
class Meta:
#表在mysql中的名字
db_table = 'Test'
- 数据库建表
在命令行执行下面两条命令,可在数据库建表,数据库存储时还会默认存储一项自增的id属性。这两条命令前者是将model层转为迁移文件migration,后者将新版本的迁移文件执行,更新数据库。
python manage.py makemigrations
python manage.py migrate
默认情况下这两个命令作用于全局,如果想仅仅对部分app进行作用的话 则执行如下命令:
python manage.py makemigrations appname
python manage.py migrate appname
如果要想精确到某一个迁移文件则可以使用:
python manage.py makemigrations appname filename
python manage.py migrate appname filename
-
增删改查
想要对数据库中已经建立的表进行任何操作,均需要引用models中的模型,如在同一App下可用“.”表示同级目录from .models import Test
增删改查的任何操作均有Django已经封装好的函数来实现,这里大致记录一下,详细的以后另写
-
增
test1 = Test(user='root',password='123456')
test1.save() -
删
删除id=1的数据test1 = Test.objects.get(id=1)
test1.delete()另外一种方式
Test.objects.filter(id=1).delete()
删除所有数据
Test.objects.all().delete()
-
改
修改其中一个id=1的name字段,再save,相当于SQL中的UPDATEtest1 = Test.objects.get(id=1)
test1.user= 'Google'
test1.save()另外一种方式
Test.objects.filter(id=1).update(user='Google')
修改所有的列
Test.objects.all().update(user='Google')
-
查
通过objects这个模型管理器的all()获得所有数据行,相当于SQL中的SELECT * FROMlist = Test.objects.all()
filter相当于SQL中的WHERE,可设置条件过滤结果
response2 = Test.objects.filter(id=1)
获取单个对象
response3 = Test.objects.get(id=1)
-
五、模板文件(html)
Django中的模版文件虽然还是.html,但本质上是html代码+逻辑控制代码组成,Django提供了一些标签、过滤器和语法等用于在html中进行控制,这里的html模板是一个文本,用于分离文档的表现形式和内容
六、静态文件
在网页中,除了html外,需要的各种css样式文件,js执行文件以及一些图片、声音、视频等,都是需要加载的动态文件。在Django中,使用static标签来加载静态文件。要使用static标签,首先需要{% load static %},之后只需要引用文件相对static文件夹的路径即可。
-
setting设置
下述两条设置在创建Django 项目的时候就已经自动设置好了,只要不修改就没问题。- 将“django.contrib.staticfiles”添加到INSTALLED_APPS中;
- 设置STATIC_URL = '/static/'
-
文件夹创建
无论在哪创建,文件夹名字都必须为static- 在app下创建一个static文件夹,在这个static文件夹下创建一个当前app的名字的文件夹,再把静态文件放到这个文件夹下。
这样做的原因是,如果直接把静态文件放在static文件夹下,那么在模版加载静态文件的时候就是使用文件名,如果在多个app之间有同名的静态文件,这时候可能就会产生混淆。而在static文件夹下加了一个同名app文件夹,在模版中加载的时候就是使用app名/文件名,这样可以避免混淆。 - 如果有一些静态文件不和任何app挂钩。即不在任何一个app目录下。那么可以在settings.py中的STATIC_URL 后面位置添加STATICFILES_DIRS,以后DTL就会在这个列表的路径中查找静态文件。例如我们在项目的根目录下新建一个static文件夹,则路径应该如下:
- 在app下创建一个static文件夹,在这个static文件夹下创建一个当前app的名字的文件夹,再把静态文件放到这个文件夹下。
STATICFILES_DIRS = [
os.path.join(BASE_DIR,"static")
]
#或者
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
- 引用方法
在模版中使用load标签加载static标签。比如要加载在项目的static文件夹下的style.css的文件。那么示例代码如下:
{% load static %}
<link rel="stylesheet" href="{% static 'style.css' %}">
要注意的是,{% load static %}需要放在html的头部位置(至少在使用static标签的上面),一般都是放在html的最上面。如果{% extend %}标签和{% load static %}同时存在,{% extend %}需要放在最上面,然后再放{% load static %}等标签。
-
偷懒方法
可以在settings中的TEMPLATES/OPTIONS添加'builtins':['django.templatetags.static'],这样以后就可以在模版中直接使用static标签,而不用手动load。