多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
使用 django-admin 来创建 HelloWorld 项目: ~~~ django-admin startproject HelloWorld ~~~ * **HelloWorld:**项目的容器。 * **manage.py:**一个实用的命令行工具,可让你以各种方式与该 Django 项目进行交互。 * **HelloWorld/\_\_init\_\_.py:**一个空文件,告诉 Python 该目录是一个 Python 包。 * **HelloWorld/asgi.py:**一个 ASGI 兼容的 Web 服务器的入口,以便运行你的项目。 * **HelloWorld/settings.py:**该 Django 项目的设置/配置。 * **HelloWorld/urls.py:**该 Django 项目的 URL 声明; 一份由 Django 驱动的网站"目录"。 * **HelloWorld/wsgi.py:**一个 WSGI 兼容的 Web 服务器的入口,以便运行你的项目。 接下来我们进入 HelloWorld 目录输入以下命令,启动服务器: ~~~ python3 manage.py runserver 0.0.0.0:8000 ~~~ 0.0.0.0 让其它电脑可连接到开发服务器,8000 为端口号。如果不说明,那么端口号默认为 8000。 在浏览器输入你服务器的 ip(这里我们输入本机 IP 地址:**127.0.0.1:8000**) 及端口号,如果正常启动,输出结果如下: ## HelloWorld/HelloWorld/urls.py 文件代码: from django.urls import path from . import views urlpatterns = \[ path('hello/', views.hello), \] 通过浏览器打开**http://127.0.0.1:8000/hello**,输出结果如下: ## path() 函数 Django path() 可以接收四个参数,分别是两个必选参数:route、view 和两个可选参数:kwargs、name。 语法格式: ~~~ path(route, view, kwargs=None, name=None) ~~~ * route: 字符串,表示 URL 规则,与之匹配的 URL 会执行对应的第二个参数 view。 * view: 用于执行与正则表达式匹配的 URL 请求。 * kwargs: 视图使用的字典类型的参数。 * name: 用来反向获取 URL。 Django2. 0中可以使用 re\_path() 方法来兼容 1.x 版本中的**url()**方法,一些正则表达式的规则也可以通过 re\_path() 来实现 。 ~~~ from django.urls import include, re_path urlpatterns = [ re_path(r'^index/$', views.index, name='index'), re_path(r'^bio/(?P<username>\w+)/$', views.bio, name='bio'), re_path(r'^weblog/', include('blog.urls')), ... ] ~~~ 我们当然可以像上篇文章中的Hello World一样,在Django的主模块中加各种功能,但当项目变得巨大的时候,各种各样的功能全都放在这里,就会显得太过杂乱,缺乏逻辑性和层次性。 Django中App的作用就在于此,我们可以将不同类型的功能分成多个不同的App应用来开发,就如同手机上不同的App有不同的功能一样,由手机系A统分别对其使用。 ### 一、App创建和配置 创建App只需要在命令行输入命令: > python manage.py startapp loginworld 该命令没有任何返回信息,但执行完后会在项目列表出现一个新的子app文件夹, ![](//upload-images.jianshu.io/upload_images/17476333-3d7548bff2f5a53f.png?imageMogr2/auto-orient/strip|imageView2/2/w/239/format/webp) 此时仅仅是app创建完成,还需要在setting的INSTALLD\_APPS 列表中进行配置才能正常使用该app应用 ![](//upload-images.jianshu.io/upload_images/17476333-a12d46d9ba8401a2.png?imageMogr2/auto-orient/strip|imageView2/2/w/622/format/webp) ### 二、路由设置(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, ![](//upload-images.jianshu.io/upload_images/17476333-85e368baa0d1b772.png?imageMogr2/auto-orient/strip|imageView2/2/w/475/format/webp) 我们需要在主路由中引入新建的子App的路由地址,方法如下 ![](//upload-images.jianshu.io/upload_images/17476333-8c09a712c4f40603.png?imageMogr2/auto-orient/strip|imageView2/2/w/980/format/webp) 同理推广,我们也可以在子app上再加下级路由连到其他app或别的地方,由此设计出更复杂的多级路由 * 子路由 新建的子App默认是没有urls的,我们需要在App目录下新建一个urls.py文件作为子路由,在此处匹配该App对应的各种功能 在设置路由时,可以在path使用name参数为其命名,这样就可以在views页面和html页面通过该名字反向获取URL使用路由 ![](//upload-images.jianshu.io/upload_images/17476333-87c269fd07e16c75.png?imageMogr2/auto-orient/strip|imageView2/2/w/794/format/webp) * 项目中存在多个App,且App内功能有重复命名时: 比较简单的做法是在每个App的urls页面分别设置一个不同的`app_name`,如 ~~~bash #app1.urls.py app_name = 'app1' ~~~ ~~~bash #app2.urls.py app_name = 'app2' ~~~ 即可在views和html中准确使用路由: ~~~bash reverse('app01:hello') reverse('app02:hello') {% url 'app02:hello' %} ~~~ 如果要实现代码的复用,或者了解app\_name和namespace的区别可以参考[https://www.jianshu.com/p/404500a0408a](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中可按如下方法建表: ~~~python # 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中默认配置如下 ![](//upload-images.jianshu.io/upload_images/17476333-1557e3e3635afb81.png?imageMogr2/auto-orient/strip|imageView2/2/w/1099/format/webp) 如果在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文件夹,则路径应该如下: ~~~csharp STATICFILES_DIRS = [ os.path.join(BASE_DIR,"static") ] #或者 STATIC_ROOT = os.path.join(BASE_DIR, 'static') ~~~ * 引用方法 在模版中使用load标签加载static标签。比如要加载在项目的static文件夹下的style.css的文件。那么示例代码如下: ~~~cpp {% 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。