python的django项目制作思路(详细)个人总结

总结:

1.回顾django建站的思路:

一、Django简介

1.web框架介绍

别人已经设定好的一个web网站模版,你学习它的规则,然后”填空“或”修改“成自己需要的样子。一般web框架的架构是这样的:

                         

其它基于python的web框架,如tornado、flask、webpy都是在这个范围内进行增删裁剪的。例如tornado用的是自己的异步非阻塞"wsgi",flask则只提供了最精简和基本的框架。Django则是直接使用了wsgi,并实现了大部分功能。

2.MVC/MTV介绍

MVC:全名Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。

通俗解释:一种文件的组织和管理形式!不要被缩写吓到了,这其实就是把不同类型的文件放到不同目录下的一种方法,然后取了个高大上的名字。当然,他带来的好处有很多,比如前后端分离,松耦合等等,就不详细说明了。

模型(model):定义数据库的相关的内容,一般放在models.py文件中。

视图(view):定义HTML等锦涛网页文件相关,也就是那些html、css、js等前端的东西。

控制器(controller):定义业务逻辑相关,就是你的主要怕代码。

MTV:有些WEB框架觉得MVC的字面意思很别扭,就给它改了一下。view不再是HTML相关,而是主业务逻辑了,相当于控制器。html被放在Templates中,称作模板,于是MVC就变成了MTV。这其实就是一个文字游戏,和MVC本质上是一样的,换了个名字和叫法而已,换汤不换药。而Django就是用的这种模型组织。

        

3.Django的MTV模型组织

目录分开,就必须有机制将他们在内里进行耦合。在Django中,urls、orm、static、settings等起着重要的作用。一个典型的业务流程是如下图所示:

                                      

二、Django项目实例

1.程序安装

python版本和django的版本要按照一下进行对应,不然会出现各种bug。

2.创建项目

使用django提供的命令和虚拟环境进行项目开发。(如果是pycharm专业版,可以快速创建项目)

这样就会发现项目中自动生成下面的目录结构:

与项目同名的目录中是配置文件,templates目录是html文件存放也就是MTV中的T(手动新建)。manage.py是django项目管理文件。

3.创建APP

在每个django项目中可以包含多个APP,相当于一个大型项目中的分系统、子模块、功能部件等,相互之间比较独立,但也有联系。

这里我创建一个叫做app01的APP,django自动生成”app01“文件夹。记得将这个app添加到设置模块中去,不然不生效。

4.编写路由

路由都在urls文件里,它将浏览器输入的url映射到相应的业务处理逻辑。

简单的urls编写方法如图:

5.编写业务逻辑

业务处理逻辑都在views.py文件里。

通过上面两个步骤,我们将index这个url指向了views.index()函数,它接收用户请求,并返回一个叫”Hello World!“的字符串。

6.运行web服务

现在我们已经可以将web服务运行起来了。命令行的方式是:

python manage.py runserver 1234

运行结果如下:

至此,一个最简单的django编写的web服务就启动成功了。

7.返回HTML文件

上面我们返回给用户浏览器的是什么?一个字符串!实际上这肯定不行,通常我们都是将html文件返回给用户。

下面,我们将写这么一个index.html文件:

为了让django知道我们对应的html文件在哪里,需要settings文件的相应内容。但默认情况下,它正好适用,无需修改。

接下来,我们可以重新启动web服务。在浏览器刷新一下,你会看到带有样式的"Hello World!"。

8.使用静态文件

我们可以将html文件返回给用户了,但是换不够,前段三大块,html、css、js还有各种插件,它们齐全才是一个完整的页面。在django中,一般将静态文件放在static目录下,接下来,在mysite2中新建一个static目录。

你的CSS,JS和各种插件都可以放置在这个目录里。

为了让django找到这个目录,依然需要对settings进行配置:

而后,为了便于管理自己的前端文件,我们可以继续建文件夹:

引入时候是这样的:

重新启动web服务,刷新浏览器,查看结果。

9.接收用户发送的数据

上面,我们将一个要素齐全的html文件返回给了用户浏览器。但这还不够,因为web服务器和用户之间没有动态交互。

下面我们设计一个表单,让用户输入用户名和密码,提交给index和url,服务器将收到这些数据。

先修改index.html文件

然后修改views.py文件

注意,django有一个请求保护机制,我们需要在settings文件中将它关闭。

进入浏览器,刷新页面:

输入点东西,然后在pycharm中可以看到相应的数据。

10.返回动态页面

我们收到了用户的数据,但返回给用户的依然是个静态页面,通常我们会根据用户的数据,进行处理后再返回给用户。

这时候,django采用jinja2语言编写动态模版,jinja2会根据提供的数据,替换掉html的相应部分,详细语法入门后再深入学习。

先改造views.py文件:

再改造index.html文件:

重新启动浏览器:

这我们可以看到,我们获得了用户的实时输入的数据,并将它实时展示在用户页面上,这是个不错的交互的过程。

11.使用数据库

流程走到这里,django的MTV框架基本已经浮出水面了,只剩下最后的数据库部分了。

上面我们虽然和用户交互得很好,但并没有保存任何数据,页面一旦关闭,或服务器重启,一切都将回到原始状态。

使用数据库是毫无疑问的,下面使用mysql数据

在settings中,配置数据库相关的参数,如果使用自带的sqlite,不需要修改。然后在mysql数据库创建mysite库。

再编辑models.py文件,也就是MTV中的M。

这里我们创建2个字段,分别保存用户的名字和密码。

接下来要在后台通过2条命令创建数据库的表,先makemigrate,然后migrate。

修改views.py中的业务逻辑:

重启web服务后,刷新浏览器页面,之后和用户交互的数据都能保存到数据库中。任何时候都可以从数据库中读取数据,展示到页面上。

三、Django总结

Django,它的功能强大,内容全面,但同时也意味着限制颇多,灵活性低,可修改性差,这就是鱼和熊掌不可兼得了。我们学习Django,其实就是学习一个软件,要理解它的基本原理,把握它整体框架,牢记一些基本规则,剩下的就是不断深入细节,然后熟能生巧、积累经验。

猜你喜欢

转载自blog.csdn.net/qq_45743005/article/details/107134059