app用来实现一个独立的功能,视图一般都写在app的view.py中,并且视图的第一个参数永远是request,视图的返回值必须是HttpResponseBase对象或子类的对象。
创建一个app:first_project
进入项目所在文件夹,python manage.py startapp appname
views.py视图函数如下
from django.http import HttpResponse # Create your views here. def book(request): return HttpResponse('Home page of book') def book_detail(request,book_catagory,book_id): #这两个参数的名字要与url.py中的参数名称一致 text='The book is in %s catagory,and it's id is %s'%(book_catagory,book_id) return HttpResponse(text) def book_author(request): author_name=request.GET.get('name')#通过request.GET.get获取输入的参数 text = 'The author of the book is %s'%author_name return HttpResponse(text)
对应项目的url.py如下
from django.http import HttpResponse from book import views #需要引入book项目的视图 def index(request): return HttpResponse('首页') urlpatterns = [ path('', index), #定义输入参数为空的返回情况 path('admin/', admin.site.urls), path('book/',views.book), path('book_detail/<book_catagory>/<book_id>',views.book_detail),#尖括号表示可以在浏览器中传入的参数,注意此处的参数名称要与视图函数定义的参数名称一致 path('book_author/',views.book_author) ]
以上,如果调用book_detail,可在浏览器中输入http://127.0.0.1:8000/book_detail/health/3
以上,如果调用author,可以再浏览器中输入http://127.0.0.1:8000/book_author?name=libai
创建多个app:url_name_demo
先创建一个项目:django-admin startproject url_name_demo
再在这个项目下创建两个app:
cd url_name_Demo
python manage.py startapp front
python manage.py startapp cms
然后手动在front和cms的app里分别创建urls.py文件
front和cms的views.py文件分别如下
#front from django.shortcuts import render from django.http import HttpResponse # Create your views here. def index(request): return HttpResponse('Home page of front') def login(request): return HttpResponse('Login of front') #cms from django.shortcuts import render from django.http import HttpResponse # Create your views here. def index(request): return HttpResponse('Home page of cms') def login(request): return HttpResponse('Login of cms')
front和cms的urls.py文件分别如下
#front from django.urls import path from . import views urlpatterns=[ path('',views.index), path('login/',views.login) ] #cms from django.urls import path from . import views urlpatterns=[ path('',views.index), path('login/',views.login) ]
整个项目的urls.py文件如下
from django.contrib import admin from django.urls import path,include #还需导入include urlpatterns = [ path('admin/', admin.site.urls), path('',include('front.urls')), #通过include将app的url与app的视图关联起来 path('cms',include('cms.urls')) ]
运行整个项目:
在浏览器输入http://127.0.0.1:8000/,显示Home page of front
在浏览器输入http://127.0.0.1:8000/login,显示Login of front
在浏览器输入http://127.0.0.1:8000/cms,显示Home page of cms
在浏览器输入http://127.0.0.1:8000/cms/login,显示Login of cms
网页跳转:
模块导入:from django.shortcuts import redirect
实现跳转:return redirect('/login') 参数为指定要跳转的功能网页,/login会重新从urls文件的路径中去进行匹配。
通过redirect('/login')实现网页跳转,通过render(request,'*.html')也可以实现同样效果,但是两者有实质性的区别。通过redict实现跳转,会根据redict指定的路径重新去urls文件进行路径匹配并执行相应的函数再返回网页,在浏览器中看到的也是一个新的url地址,而直接通过render进行跳转,只是将指定网页渲染出来,浏览器看到的url地址并不会发生改变。
url取名:
上述例子中的所有url的名称一旦改变,其他所有需要跳转到该url的引用都需要修改,为避免出现这个问题,可以给url取一个名字,后续通过反转这个url这个名字去找到对应的url
from django.shortcuts import redirect,reverse
路径写法:path('login/',views.login,name='login')
实现跳转:return redirect(reverse('login'))
即后续login/的url不论如何改变,改变成logging/、signin或者其他,都可以通过reverse('login')找到对应的url
由于多个app可能存在相同的url,为了避免在反转时对url产生混淆,可以在每个app的urls.py文件中通过app_name指定应用命名空间即可,后续在反转时同时指定命名空间和url
例如front app的urls.py文件中指定app_name='front'
路径写法:path('login/',views.login,name='login')
实现跳转:return redirect(reverse(front:'login'))