Django-App及各模块详解

本篇主要介绍了Django的App及各模块功能、配置情况,具体的各种语法及函数,后面有空会分篇记录

我们当然可以像上篇文章中的Hello World一样,在Django的主模块中加各种功能,但当项目变得巨大的时候,各种各样的功能全都放在这里,就会显得太过杂乱,缺乏逻辑性和层次性。
Django中App的作用就在于此,我们可以将不同类型的功能分成多个不同的App应用来开发,就如同手机上不同的App有不同的功能一样,由手机系A统分别对其使用。

一、App创建和配置

创建App只需要在命令行输入命令:

python manage.py startapp loginworld

该命令没有任何返回信息,但执行完后会在项目列表出现一个新的子app文件夹,
  • 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,
    {% 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中的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。