Django个人博客开发之高级优化路由、视图

我们之前已经完成了项目的结构搭建,但是,在Django当中,我们强调的一个重要概念是app,比如Django自带的admin就是一个成功的app典范,那么我们应该如何整理自己的项目结构,才能让我们的app真正的独立出来,我们以之前的OurBlog项目为例:
为了项目的可迁移性,我们将静态文件和模板文件的目录创建到APP的目录下,在app外部,也就是我们项目的根目录下,我们创建一个空的静态文件目录:
在这里插入图片描述
然后在app(Article)当中的static和template当中创建和app同名的目录来存放文件,即static–>Article–>文件,template–>Article–>文件。
在这里插入图片描述
注意,Django在配置完成之后,在项目目录下执行收集静态文件的命令之后,python manage.py collectstatic,会自动检索所有的app的目录,然后将目录下的static目录下的文件收集到指定的路径(这个路径,在settings当中通过STATIC_ROOT来配置)下。所以,为了区分各个app的静态文件,我们将app的静态文件存放到static目录下的app同名下的目录当中。至于template创建和app同名的目录的目的是区分各个APP下同名的HTML文件,比如:
Article/index.html
User/index.html
然后配置settings
OurBlog/OurBlog/settings.py

# ...... 
#安装功能
INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'Article', #我们自定义的功能
    'ckeditor', #Django ckeditor的功能
    'ckeditor_uploader', #Django ckeditor的上传功能
)

# ......

#模板配置
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [
        ],
        'APP_DIRS': True, #是否搜索app当中的模板目录
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

# ...... 
STATIC_ROOT = os.path.join(BASE_DIR,"static").replace("\\","/") # 这里其实也可以不加这个replace方法,上面已经为我们写好了置换方法

注意,这里我们修改的有这些,其他的配置和之前学习过程当中一样。
然后我们来进行静态文件的收集
命令:python manage.py collectstatic
这里可以在pycharm自带的Teminal下执行,也可以在cmd下切换到项目目录下执行该命令。
在这里插入图片描述
在这里插入图片描述
然后,Django就会把app当中的静态文件放到项目的静态目录下
在这里插入图片描述
这个时候我们的配置完成了,要调整的就是视图当中模板文件的加载和前端文件的渲染了
/OurBlog/Article/views.py

from django.shortcuts import render

def base(request):
    return render(request, "Article/base.html")

def index(request):
    return render(request, "Article/index.html")

def myArticle(request):
    return render(request, "Article/myArticle.html")

def myPicture(request):
    return render(request, "Article/myPicture.html")

def aboutMe(request):
    return render(request, "Article/aboutMe.html")

def connectMe(request):
    return render(request, "Article/aboutMe.html")

在这里我们之前加载的文件是在根目录下的template下,现在修改到了app下,访问的时候也要注意前端样式的加载
在这里插入图片描述
这样我们再次访问页面,就发现已经把app独立的静态目录开发功能编写完成了。
效果如下
在这里插入图片描述
上面完成了静态文件的优化,那么接下来优化路由部分,路由本身优化有两个方向,我们首先来看针对app独立的优化,很简单,在app当中创建独立的路由文件,urls.py
1、 在app当中创建urls
在这里插入图片描述
2、 在app当中的urls当中导入url设置,设定路由

#coding:utf-8

from django.conf.urls import url
from Article.views import *
urlpatterns = [
    url(r'^index/', index),
    url(r'^myArticle/', myArticle),
    url(r'^myPicture/', myPicture),
    url(r'^aboutMe/', aboutMe),
    url(r'^connectMe/', connectMe),
]

3、 在主url当中包含子url

from django.conf.urls import include, url
from django.contrib import admin

urlpatterns = [
    #........
url(r'^article/', include('Article.urls')),
    #........
]

4、然后进行访问,如上图的效果

猜你喜欢

转载自blog.csdn.net/ALLENsakaru/article/details/84112939