目录
2.1 整体结构
2.2 Model
2.3 View
2.4 Template
PART 3. 代码风格  
3.1 docstring
3.2 多返回值
PART 4. 路由组织  
4.1 路由系统
4.2 路由包含
4.3 命名空间
首页 运维 安全 Django开发方法是什么

Django开发方法是什么

May 19, 2023 pm 05:44 PM
django

PART 1. 开始之前

Django作为一款功能强大的Web应用框架,近年来逐步受到大家的欢迎,越来越多的Python开发者投入到Django的怀抱中,但是同样由于Django中的众多内容,大家在初入Django时总会感到有一些『心有余而力不足』,不知道从何处下手。或者在初步了解之后,仍不确定当前方法是否优雅,不知道如何组织项目,以及如何使代码重用性更高。

PART 2. 项目架构 

好的项目结构是成功的一半。

2.1 整体结构

在默认情况下,由Django生成的项目结构大概是这样的:

Django开发方法是什么

随着项目中的Application不停的增加,本地根目录下的package会不停的变多,导致越来越难维护,所以我们要对整个项目有一个清晰的规划,合理的放置各个文件的位置。

如果项目较小,且不打算将其中的Application进行各种复用,可以考虑如下方式:

Django开发方法是什么

venv文件夹存放项目的virtualenv环境,非必须,可以放置在其他地方。

database这个App专门用于存放model、manage的命令以及模板中用到的一些自定义filters,存放在项目根目录下。

docs和logs分别存放工程的相关文档和运行时产生的log文件。

static存放静态文件,例如css/js/img/font等。

utils存放工程中用到的工具函数、类,以及一些通用的模块,例如logger等。

templates存放模板文件,父模板或被多个模板继承的模板放在根目录,并且以base之类的名称命名,方便维护,其余的模板放在对应的application名字的文件夹中。

web目录存放所有的Application,如果有很多的Application,可以在此基础上分成更多的package来规划,每个package里存放一类的Application。

2.2 Model

在Model模块部分,我们主要关心数据到类的映射,一般情况下,每张表对应的类将放置在单独的文件中,并在models/__init__.py中将对应的类依次导入,这样在其他地方使用时可以通过from database.models import xxxx导入,给类命名时建议添加上项目的名称,例如我这里有个项目的名字是Cherry,那么所有的类均为CherryLeaks,CherryVulns等,在reivew代码以及编写的过程中会一目了然,知道这个类代表了数据。

建议为Models添加单独的manager,并实现相应的方法,以避免进行重复操作。

除此之外,还有一些建议,可以根据实际情况取舍:

不建议使用外键等类型

每张表添加is_deleted,created_time,updated_time字段

善用索引

2.3 View

大多数业务逻辑应该放在View部分,此部分应该是最核心的。这里也是推荐将功能相近的View全部放置在同一个文件中。方便未来的维护和开发,该文件应被放置于名为 "controller" 或 "view" 的包中。例如处理project相关的路由,全部放置在controller/project.py中。

优先使用Django内置的一些View类,例如ListView,TemplateView等,如果需要自己实现View的情况,推荐使用Class-based view,将不同的请求方法封装到不同的方法中,方便日后维护。

2.4 Template

对于模板文件而言,最好的方法就是将不同的页面、功能切割为不同的模板文件,并按Applicatio的名称按文件夹存放,这样在后期维护时,可以快速的从每个Application找到对应的模板文件。

除此之外,强烈推荐使用模板的继承功能,所有的页面均从父模板继承下来,并且使用各种block来扩充页面,父模板中定义好每个位置的block名称,供子模板覆盖。建议使用通俗简短的名称为每个block命名,例如:sidebar,script,header,main_content,page_title,page_description等。

对于通用的功能,例如评论框,可以考虑单独存放在一个文件中,在需要的地方通过{% include 'filename.tpl.html' %}加载进来。需要注意的是,如果你需要同时使用extends和include指令,一定要在block中使用,否则是无效的。如下例子是无效的:

Django开发方法是什么

应当按照如下方式使用:

Django开发方法是什么

PART 3. 代码风格  

3.1 docstring

Python语言的灵活性,使得我们有时会在写代码时忘记特定方法的参数类型或返回类型。在此情况下,我们需要使用docstring为每个方法提供清晰的信息标注,以便其他人进行开发和维护。参考这个链接,如果你在使用PyCharm,可以编写自动补全docstring。

3.2 多返回值

很多情况下,我们的方法需要返回多个值给调用方,或者通过JSON返回给前端,如果胡乱的返回数据,就会导致开发混乱,到最后根本不知道方法返回了什么东西。

一个比较好的做法就是约定好返回的格式,对于返回给调用方而言,简单的返回tuple即可,并在docstring中写明每个值的含义。除了返回结果,有时我们需要返回一个err,以表明在处理数据过程中是否出现了问题或异常。一般情况下有几种可用的方法:

通过raise抛出异常

通过多返回值返回,例如err, result = func()

通过类中的一个属性返回,例如instance = Class(); err = instance.error_message

这三种方法均有利弊,需要根据项目的实际情况来选取,无论使用哪一种方法,都需要在整个项目中保持统一,尽可能的不要混合使用;

对于返回给前端的JSON,就需要稍微复杂一些,至少要返回2~3个字段:

Django开发方法是什么

code是本次调用返回的状态码,根据实际情况自行约定。message 是状态码的易于理解的信息,可供开发人员调试并向用户提供通知。data是实际返回的数据信息,很多时候可以不需要这个字段,具体的字段格式也需要根据实际情况再次进行约定。

PART 4. 路由组织  

优雅简单的路由保证项目质量,降低维护成本。

4.1 路由系统

Django有一套强大的路由系统以及路由算法,可以满足业务中的各种需要,并且配置灵活简单,每一个路由配置文件都是URL PATH到function/class的映射。全部都可以自己设置,完全不会受到框架或是其他的一些限制。可以参考文档中关于Django请求路由寻找策略的这一部分。

在配置路由中,你可以用尖括号括起来一些变量,便于在后面使用。尖括号里可以用一些"路径转换器(Path Converters)"来指定变量类型,例如str, int, slug, uuid, path。一个完整的URL路由文件看起来像下面这样:

Django开发方法是什么

除此之外,还可以通过re_path在路由中设置正则匹配:

Django开发方法是什么

有些时候,你可能希望为一些URL添加一个默认路由,例如访问/blog/的时候返回一个默认页面,而访问/blog/page的时候返回指定页码的内容,可以通过如下方式配置

Django开发方法是什么

4.2 路由包含

随着项目的不断扩大,用到的路由也会不断的变多,所以Django提供了路由包含的机制,便于我们在不同的App中组织路由。我们来看一个简单的例子:

Django开发方法是什么

这个例子中,将所有请求community/*的路由全部交由aggregator.urls去解析,同理,contact/*的请求也全部交给了另外的路由模块去处理;如果你的项目中并没有这么多的Application,依然想通过include的方式来管理路由,那么可以采用如下方式:

Django开发方法是什么

4.3 命名空间

一般情况下,我们的每个Django项目都由多个App组成,如果把所有App的路由全部放在URLCONF_ROOT里,时间久了这个文件会变的越来越难维护,十分混乱。在不同的App中可能会使用相同名称的路由,导致冲突。为了解决这些问题,我们可以通过使用"路由包含"和"命名空间"来解决,特别是如果你在维护一个可以被复用的App,为了保证路由的唯一,命名空间就显得尤为重要了。

命名空间通常有两种:Application namespace和Instance namespace,例如admin:index表示admin命名空间的index路由。更多关于该部分的内容可以参考:官方文档

Application Namespace比较好理解,指的是在应用程序层面上的命名空间,一般是如下方式组织的:

Django开发方法是什么

Instance Namespace则指的是实例级别的命名空间,常用于一个App被多次实例化的情况,为了区分每个实例,就需要引入Instance Namespace。我们使用官方文档中的例子看一下:

Django开发方法是什么

可以看到两个路由author-polls和publisher-polls其实都包含了相同的路由,但是指定了不同的命名空间,这就是Instance级别的命名空间,即当前正在访问的对象的命名空间。不同的用户身份访问不同的URL,会得到不同的命名空间,例如游客和管理员均访问polls:index所指向的页面,但是由于命名空间的不同,会得到完全不同的结果。

以上是Django开发方法是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

怎么看django版本 怎么看django版本 Dec 01, 2023 pm 02:25 PM

查看django版本步骤:1、打开终端或命令提示符窗口;2、确保已经安装了Django,如果没有安装Django,可以使用包管理工具来进行安装,输入pip install django命令即可;3、安装完成后,可以使用python -m django --version来查看Django的版本。

Django vs. Flask:Python Web框架的对比分析 Django vs. Flask:Python Web框架的对比分析 Jan 19, 2024 am 08:36 AM

Django和Flask都是PythonWeb框架中的佼佼者,它们都有着自己的优点和适用场景。本文将对这两个框架进行对比分析,并提供具体的代码示例。开发简介Django是一个全功能的Web框架,它的主要目的是为了快速开发复杂的Web应用。Django提供了许多内置的功能,比如ORM(对象关系映射)、表单、认证、管理后台等。这些功能使得Django在处理大型

Django框架的优点和缺点:您需要知道的一切 Django框架的优点和缺点:您需要知道的一切 Jan 19, 2024 am 09:09 AM

Django是一个完整的开发框架,该框架涵盖了Web开发生命周期的各个方面。目前,这个框架是全球范围内最流行的Web框架之一。如果你打算使用Django来构建自己的Web应用程序,那么你需要了解Django框架的优点和缺点。以下是您需要知道的一切,包括具体代码示例。Django优点:1.快速开发-Djang可以快速开发Web应用程序。它提供了丰富的库和内

如何升级Django版本:步骤和注意事项 如何升级Django版本:步骤和注意事项 Jan 19, 2024 am 10:16 AM

如何升级Django版本:步骤和注意事项,需要具体代码示例引言:Django是一个功能强大的PythonWeb框架,它持续地进行更新和升级,以提供更好的性能和更多的功能。然而,对于使用较旧版本Django的开发者来说,升级Django可能会面临一些挑战。本文将介绍如何升级Django版本的步骤和注意事项,并提供具体的代码示例。一、备份项目文件在升级Djan

django版本区别是什么 django版本区别是什么 Nov 20, 2023 pm 04:33 PM

区别是:1、Django 1.x系列:这是Django的早期版本,包括1.0、1.1、1.2、1.3、1.4、1.5、1.6、1.7、1.8和1.9等版本。这些版本主要提供基本的Web开发功能;2、Django 2.x系列:这是Django的中期版本,包括2.0、2.1、2.2等版本;3、Django 3.x系列:这是Django的最新版本系列,包括3.0、3等版本。

django是前端还是后端 django是前端还是后端 Nov 21, 2023 pm 02:36 PM

django是后端。详细介绍:尽管Django主要是一个后端框架,但它与前端开发密切相关。通过Django的模板引擎、静态文件管理和RESTful API等功能,前端开发人员可以与后端开发人员协作,共同构建功能强大、可扩展的Web应用程序。

怎么查看django版本 怎么查看django版本 Nov 30, 2023 pm 03:08 PM

查看django版本的方法:1、通过命令行查看,在终端或命令行窗口中输入“python -m django --version”命令;2、在Python交互式环境中查看,输入“import django print(django.get_version())”代码;3、检查Django项目的设置文件,找到名为INSTALLED_APPS的列表,其中包含已安装的应用程序信息。

Django、Flask和FastAPI:哪个框架适合初学者? Django、Flask和FastAPI:哪个框架适合初学者? Sep 27, 2023 pm 09:06 PM

Django、Flask和FastAPI:哪个框架适合初学者?引言:在Web应用开发领域,有许多优秀的Python框架可供选择。本文将重点介绍Django、Flask和FastAPI这三款最受欢迎的框架。我们将评估它们的特点,并讨论哪个框架最适合初学者使用。同时,我们还将提供一些具体的代码示例,以帮助初学者更好地理解这几个框架。一、Django:Django

See all articles