Django-App及各模块详解

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

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

一、App创建和配置

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

python manage.py startapp loginworld

该命令没有任何返回信息,但执行完后会在项目列表出现一个新的子app文件夹,

此时仅仅是app创建完成,还需要在setting的INSTALLD_APPS 列表中进行配置才能正常使用该app应用

二、路由设置(urls)

  • 路由规则

    1. urlpatterns中的元素按照书写顺序从上往下逐一匹配正则表达式,一旦匹配成功则不再继续。
    2. 当浏览器访问请求的url不是以/结尾时,jango会自动给该请求加/结尾,并让浏览器重新访问.可设置为不主动加结尾处的/,方法:在settings.py文件中加入APPEND_SLASH=False即可,配置文件中虽然没有这个参数,但默认结果是True;当配置完成后url请求后不加/时是访问不到页面的。
    3. URLconf匹配的位置: URLconf 在请求的URL 上查找,将它当做一个普通的Python 字符串,会取 网址之后?号之前的字符串来做正则匹配. 且匹配出来的所有东西都是字符串形式。
  • 分发思路
    把本该在项目目录下的urls.py中进行路由匹配的功能给分发到各个不同的App内,在其中新建urls.py文件来进行路由匹配;在项目目录下的urls.py中建立分发指引路径

  • 主路由

    主路由或者说全局路由通过setting中的ROOT_URLCONF确定,默认为Django文件夹下的urls,
    我们需要在主路由中引入新建的子App的路由地址,方法如下

    同理推广,我们也可以在子app上再加下级路由连到其他app或别的地方,由此设计出更复杂的多级路由

  • 子路由
    新建的子App默认是没有urls的,我们需要在App目录下新建一个urls.py文件作为子路由,在此处匹配该App对应的各种功能

    在设置路由时,可以在path使用name参数为其命名,这样就可以在views页面和html页面通过该名字反向获取URL使用路由
  • 项目中存在多个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的区别可以参考//www.greatytc.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。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 项目部署到阿里云(nginx+uwsgi)上后,静态文件加载没有问题。但是在本地,使用开发服务器,却始终加载不成功...
    兰山小亭阅读 10,925评论 0 9
  • PythonWeb框架要点、Django介绍、工程搭建、配置、静态文件与路由 1.Python Web 框架要点 ...
    Cestine阅读 5,556评论 0 6
  • 处理静态文件,尤其是在开发时,是一件很头疼的事情。在这篇文章中,我们将会讨论一些设置,目录结构和他们之间的相互影响...
    51reboot阅读 5,636评论 0 1
  • Django的来历:python开发的! long long long years ago!劳伦斯出版集团新闻 网...
    JAguys阅读 2,806评论 0 0
  • Django是一个用 Python 编写的 Web 框架。Web 框架是一种软件,基于web框架可以开发动态网站,...
    guanalex阅读 12,033评论 0 5