本篇主要介绍了Django的App及各模块功能、配置情况,具体的各种语法及函数,后面有空会分篇记录
我们当然可以像上篇文章中的Hello World一样,在Django的主模块中加各种功能,但当项目变得巨大的时候,各种各样的功能全都放在这里,就会显得太过杂乱,缺乏逻辑性和层次性。
Django中App的作用就在于此,我们可以将不同类型的功能分成多个不同的App应用来开发,就如同手机上不同的App有不同的功能一样,由手机系A统分别对其使用。
一、App创建和配置
创建App只需要在命令行输入命令:
python manage.py startapp loginworld
该命令没有任何返回信息,但执行完后会在项目列表出现一个新的子app文件夹,主路由或者说全局路由通过setting中的ROOT_URLCONF确定,默认为Django文件夹下的urls,
如果要实现代码的复用,或者了解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中的UPDATE
test1 = 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 * FROM
list = 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模板是一个文本,用于分离文档的表现形式和内容
需要注意的是,Django项目的所有模版文件即html都必须放在templates目录下,其在setting中默认配置如下
如果在Django项目根目录的templates中和各个app中分别创建index.html,默认访问根目录templates中的index.html文件,如果templates中不存在,则按照settings.py中App的设置顺序进行加载。
六、静态文件
在网页中,除了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文件夹,则路径应该如下:
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。