CBV(Class based views)
Python是一个面向对象的编程语言,如果只用函数来开发,有很多面向对象的优点就错失了(继承、封装、多态)。所以Django在后来加入了CBV(Class-Based-View)。CBV就是在视图里使用类处理请求。
即可以让我们用类写View。这样做的优点主要下面两种:
- 提高了代码的复用性,可以使用面向对象的技术,比如Mixin(多继承)
- 可以用不同的函数针对不同的HTTP方法处理,而不是通过很多if判断,提高代码可读性
from django.http import HttpResponse from django.views import View class TestView(View): def get(self, request): return HttpResponse('1111111111')
Django的url收到请求后,是需要把这个请求分配给一个可调用的函数的,而不是一个class。针对这个问题,class-based view提供了一个as_view()静态方法(也就是类方法),调用这个方法,会创建一个类的实例,然后通过实例调用dispatch()方法,dispatch()方法会根据request的method的不同调用相应的方法来处理request(如get() , post()等)。到这里,这些方法和function-based view差不多了,要接收request,得到一个response返回。如果方法没有定义,会抛出HttpResponseNotAllowed异常。
在url中,就这么写:
from django.urls import path from myapp1 import views urlpatterns = [ path('test3', views.TestView.as_view()) ]
cbv视图属性设置
类的属性可以通过两种方法设置,第一种是常见的Python的方法,可以被子类覆盖。
from django.http import HttpResponse from django.views import View class GreetingView(View): greeting = "Good Day" def get(self, request): return HttpResponse(self.greeting)
子类中只需继承
class MorningGreetingView(GreetingView): greeting = "Morning to ya"
第二种方法,你也可以在url中指定类的属性:
在url中设置类的属性Python
urlpatterns = [ path('about/', GreetingView.as_view(greeting="G'day")), ]
cbv视图属性设置
类的属性可以通过两种方法设置,第一种是常见的Python的方法,可以被子类覆盖。
1
2
3
4
5
6
7
8
|
from django.http import HttpResponse from django.views import View class GreetingView(View): greeting = "Good Day" def get( self , request): return HttpResponse( self .greeting) |
子类中只需继承
1
2
|
class MorningGreetingView(GreetingView): greeting = "Morning to ya" |
第二种方法,你也可以在url中指定类的属性:
在url中设置类的属性Python
1
2
3
|
urlpatterns = [ path( 'about/' , GreetingView.as_view(greeting = "G'day" )), ] |