上文我们讲到django创建项目的流程以及项目的整体结构,但是,是不是觉得就那么一点东西没什么卵用呢?就像用Xcode创建一个iOS项目,系统自动生成了appdelegate、storyboard等文件,程序是可以运行,然后如何展示我想要的页面呢?本节主要讲解在django下如何将你想要的内容展示出来。
1. django的页面是如何显示的?
用户在访问一个网址,实际上时发送了一个request请求,比如说“http://www.baidu.com”时,对应的DNS服务器将其解析为公网上的一个IP地址,然后访问该IP对应的那台服务器上的Web服务器,Web服务器将对应的程序事先设定好的响应内容返回,即返回一个response,浏览器将response显示出来,即浏览器显示的界面。这个就是用浏览器访问Web的整个流程。
那么,django要做的是什么?就是定义用户需要访问的request,以及定义每个request需要做出的响应(response)。
2. 在django下创建app
2.1 django下的app指的是什么?
django下的app即是一个功能相对独立的模块,一个django项目可以包含多个app。
2.2 django下如何创建app?
打开终端,进入到上文中创建的testblog目录下,输入以下命令:
python3 manage.py startapp blog
回车即可在该项目下创建一个名为blog的应用,但是,但是,成功的前提是你创建的应用名blog不能与系统的应用名相同,否则一定报错,有兴趣你可以创建一个名为os的应用试试。
还记得前文说到setting中的配置项么?新增加了一个app,一定要setting中增加以下,打开setting.py文件,在INSTALLED_APPS中增加‘blog’:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'blog',
]
2.3 django下app的目录结构
用PyCharm打开testblog项目,你会发现在tesgblog下多了一个blog文件夹:
migrations:
用于数据迁移
admin:
django自动生成的后台管理页面,无须在此作修改
apps:
当前app的配置文件
models:
数据模型,和其他语言的一样
views:
定义前台显示的界面
2.3 django显示app中的内容
我想访问‘127.0.0.1:8000/index’这样一个页面,然后在页面上显示一行文字“天行健,君子自强不息!”,该怎么做呢?我们按照用户访问的顺序倒推程序该如何写。
首先,访问url实际上是调用web服务器上对应目录下的方法,此例中,127.0.0.1:8000指的是web服务器,index指的是该服务器下的对象(可以是文件、类、方法等),所以我们先要在程序中定义index这个对象,在该对象中输出需要显示的内容,如上文说的,这个定义是在该app下的views中定义的:
第二,index已经定义了,该怎么让web服务器找到index呢?
上文提到,所有定义的界面都是在系统的urls.py文件里配置的
from django.conf.urls import url
from django.contrib import admin
urlpatterns = [
url(r'^admin/', admin.site.urls),
]
我们需要将index配置到该数组中即可,如下:
from django.conf.urls import url
from django.contrib import admin
from blog.views import index
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^index/', index),
]
好了,此时重新运行一下服务器,访问‘127.0.0.1:8000/index’,是不是已经看到你想要的结果了呢!
如果,testblog下面有10个app,每个app中有100个页面,那么urls.py文件中
urlpatterns数组要增加1000条记录,你还要记住每条记录属于哪个app,而且这1000条记录还不能重名,是不是很酸爽?不怕,我们有其他办法:我们在每一个app下新建一个urls.py文件,该文件的作用域就是该app,然后再在系统生成的urls.py文件中引用各app中的urls.py,这样维护起来就比较简单了。
首先,在blog文件夹下新建一个名为blog_urls.py的文件,将系统urls.py中的内容全部复制过来,去掉不需要的东西,如下:
from django.conf.urls import url
from . import views
urlpatterns = [
url(r'^index/', views.index),
]
然后在系统的urls.py文件中使用include函数将blog_urls的路径引用进来,如下:
from django.conf.urls import url, include
from django.contrib import admin
from blog.views import index
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^index/', include('blog.blog_urls')),
]
此时运行程序,访问一下 127.0.0.1:8000/index/,我靠,是不是报404错误?
我们来分析一下,程序接收到页面的请求后先去系统的urls.py文件中找名为index的路径,找到了 url(r'^index/', include('blog.blog_urls'))这条记录,这个纪录中include函数又去blog下找到blog_urls.py函数,然后又找到了一条记录url(r'^index/', views.index),该记录中还有一个index,此时的路径就成了index/index/,不信,你可以访问127.0.0.1:8000/index/index/,一定可以看到你想要的记录。
blog是第一个独立的app,我们访问blog下的index,最好把urls.py文件改为
from django.conf.urls import url, include
from django.contrib import admin
from blog.views import index
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^blog/', include('blog.blog_urls')),
]
这样,可以访问 127.0.0.1:8000/blog/index/来访问页面。