Django
遵循MVC设计模式的框架,MVC是Model、View、Controller的三个单词的简写。分别代表模型、视图、控制器。

创建项目
项目结构介绍
- manage.py:和项目交互都基于这个文件,python manage.py [子命令]
- settings.py:本项目的设置项,所有和项目相关的配置都是放在这个里面
- urls.py:用来配置URL路由的,比如访问http://127.0.0.1/news/ 是访问新闻列表页,这些东西就需要在这个文件中完成。
- wsgi.py:项目与WSGI协议兼容的web服务器入口,部署的时候需要用到的,一般情况下也是不需要修改的。
创建app
python manage.py startapp django_1
视图函数
- 视图函数的第一个参数必须是request,这个参数不能少
- 视图函数的返回值必须是
django.http.response.HttpResponseBase的子类的对象。
URL传递参数
- url映射
- 要去urls.py文件中寻找映射是因为在settings.py文件中配置了
ROOT_URLCONF为urls.py。所有的django会去urls.py中寻找。
- 在
urls.py中我们所有的映射都应该放在urlpatterns这个变量中。
- 所有的映射不是随便写的,而是使用
path函数或者是re_path函数进行包装的。
- url传参数
url命名
- 需要url命名的原因
因为url是经常变化的,写死可能会经常修改代码。给url取个名字以后使用url的时候就使用它的名字进行反转就可以了。
-
如何给一个url指定名称
在path函数中,传递一个name参数就可以指定。
# urls.py
from django.urls import path
from . import views
urlpatterns = [
path('',views.index,name='index'),
path('signin/',views.login,name='login')
]
# views.py
from django.http import HttpResponse
from django.shortcuts import redirect,reverse
def index(request):
username = request.GET.get('username')
if username:
return HttpResponse('首页')
else:
return redirect(reverse('login'))
-
应用命名空间
在多个app之间,有可能产生同名的url。这时为了避免反转url的时候产生混淆,可以使用应用命名空间来做区分。定义应用命名空间非常简单,只要在app的urls.py中定义一个叫做app_name的变量来指定这个应用的命名空间即可。
# urls.py
from django.urls import path
from . import views
app_name = 'front'
urlpatterns = [
path('',views.index,name='index'),
path('signin/',views.login,name='login')
]
# views.py
from django.http import HttpResponse
from django.shortcuts import redirect,reverse
def index(request):
username = request.GET.get('username')
if username:
return HttpResponse('首页')
else:
return redirect(reverse('front:login'))
- 应用命名空间和实例名空间
# 一个app可以创建多个实例,可以使用多个url映射同一个app。在做反转的时候使用应用命名空间,那么就会发生混淆,为了避免这个问题就可以使用实例命名空间。在include函数中传递一个namespace变量即可。
# urls.py
from django.urls import path,include
urlpattterns = [
path('',include('front.urls')),
path('cms1/',include('cms.urls',namespace='cms1')),
path('cms2/',include('cms.urls',namespace='cms2'))
]
url分层模块化
多个app后主app的urls.py里的urlpatterns会写入过多路径,可通过在app里创建自身app对应的urls.py来方便路径转发。
# 主urls.py,使用include函数包含子urls.py
from django.urls import path,include
urlpattterns = [
path('book/',include('book.urls'))
# 以book开头的url都会转到book app下的urls.py
]
# book app的 urls.py
from django.urls import path
from . import views
urlpattterns = [
path('',views.book),
path('detail/<book_id>',views.book_detail),
path('list/',views.book_list),
]
reverse函数补充
1、如果反转url的时候,需要添加参数,那么可以传递kwargs参数到reverse函数中。
2、如果想要添加查询字符串的参数,则必须手动的
进行拼接。
# views.py
from django.http import HttpResponse
from django.shortcuts import reverse,redirect
def index(request):
username = request.GET.get('username')
if username:
return HttpResponse("首页")
else:
# login_url = reverse('login') + "?next=/"
# return redirect(login_url)
detail_url = reverse('detail',kwargs={'article_id':1,'page':2})
return redirect(detail_url)
def login(request):
return HttpResponse("登录页面")
def article_detail(request,article_id):
text = '您的文章id是:%s' % article_id
return HttpResponse(text)
# urls.py
from django.urls import path
from front import views
urlpatterns = [
path('',views.index,name='index'),
path('login/',views.login,name='login'),
path('detail/<article_id>/<page>/',views.article_detail,name='detail')
]