FBV(function base views) 就是在视图里使用函数处理请求。html
在以前django的学习中,咱们一直使用的是这种方式。前端
CBV(class base views) 就是在视图里使用类处理请求。python
Python是一个面向对象的编程语言,若是只用函数来开发,有不少面向对象的优势就错失了(继承、封装、多态)。因此Django在后来加入了Class-Based-View。可让咱们用类写View。这样作的优势主要下面两种:django
若是咱们要写一个处理GET方法的view,用函数写的话是下面这样。编程
from django.http import HttpResponse def my_view(request): if request.method == 'GET': return HttpResponse('OK')
若是用class-based view写的话,就是下面这样后端
from django.http import HttpResponse from django.views import View class MyView(View): def get(self, request): return HttpResponse('OK')
Django的url是将一个请求分配给可调用的函数的,而不是一个class。针对这个问题,class-based view提供了一个as_view()
静态方法(也就是类方法),调用这个方法,会建立一个类的实例,而后经过实例调用dispatch()
方法,dispatch()
方法会根据request的method的不一样调用相应的方法来处理request(如get()
, post()
等)。到这里,这些方法和function-based view差很少了,要接收request,获得一个response返回。若是方法没有定义,会抛出HttpResponseNotAllowed异常。restful
在url中,就这么写:app
# urls.py from django.conf.urls import url from myapp.views import MyView urlpatterns = [ url(r'^index/$', MyView.as_view()), ]
类的属性能够经过两种方法设置,第一种是常见的Python的方法,能够被子类覆盖。框架
from django.http import HttpResponse from django.views import View class GreetingView(View): name = "yuan" def get(self, request): return HttpResponse(self.name) # You can override that in a subclass class MorningGreetingView(GreetingView): name= "alex"
第二种方法,你也能够在url中指定类的属性:编程语言
在url中设置类的属性Python
urlpatterns = [ url(r'^index/$', GreetingView.as_view(name="egon")), ]
我以为要理解django的class-based-view(如下简称cbv),首先要明白django引入cbv的目的是什么。在django1.3以前,generic view也就是所谓的通用视图,使用的是function-based-view(fbv),亦即基于函数的视图。有人认为fbv比cbv更pythonic,窃觉得否则。python的一大重要的特性就是面向对象。而cbv更能体现python的面向对象。cbv是经过class的方式来实现视图方法的。class相对于function,更能利用多态的特定,所以更容易从宏观层面上将项目内的比较通用的功能抽象出来。关于多态,很少解释,有兴趣的同窗本身Google。总之能够理解为一个东西具备多种形态(的特性)。cbv的实现原理经过看django的源码就很容易明白,大致就是由url路由到这个cbv以后,经过cbv内部的dispatch方法进行分发,将get请求分发给cbv.get方法处理,将post请求分发给cbv.post方法处理,其余方法相似。怎么利用多态呢?cbv里引入了mixin的概念。Mixin就是写好了的一些基础类,而后经过不一样的Mixin组合成为最终想要的类。
因此,理解cbv的基础是,理解Mixin。Django中使用Mixin来重用代码,一个View Class能够继承多个Mixin,可是只能继承一个View(包括View的子类),推荐把View写在最右边,多个Mixin写在左边。
https://www.cnblogs.com/yuanchenqi/articles/8715364.html
class LoginView(View): """ http_method_names = ['get', 'post', 'put', 'patch', 'delete', 'head', 'options', 'trace'] get: 查 post: 提交,添加 put: 全部内容都更新 patch: 只更新一部分 delete: 删除 """ def dispatch(self, request, *args, **kwargs): print('dispatch...') ret = super(LoginView, self).dispatch(request,*args, **kwargs) # ret = super().dispatch(request,*args, **kwargs)
类下得反射作得分发
cbv 得 本质 仍是一个 fbv
url(r'^login/', views.LoginView.as_view()),
def dispatch(self, request, *args, **kwargs):
print('dispatch...')
return super(LoginView, self).dispatch(request,*args, **kwargs)
执行父类;
CBV 先后端 分离:
from django.conf.urls import url from django.contrib import admin from app01 import views urlpatterns = [ url(r'^admin/', admin.site.urls), # url(r'^my_view/', views.my_view), url(r'^my_view/', views.MyView.as_view()), url(r'^my_view_2/', views.MyView_2.as_view(name='egon')), url(r'^login/', views.LoginView.as_view()) ] ------------------------------------------------- from django.shortcuts import render,HttpResponse def my_view(request): if request.method == 'GET': return HttpResponse('get....') from django.views import View class MyView(View): name="yuan" def get(self,request): return HttpResponse('GET请求'+self.name) class MyView_2(MyView): name = 'alex' class LoginView(View): def dispatch(self, request, *args, **kwargs): ret = super(LoginView, self).dispatch(request,*args,**kwargs) return ret def get(self,request): print('get...') return render(request,'login.html') def post(self,request): print('post...') return HttpResponse('post....') def put(self): pass --------------------------------------------------------
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <form action="" method="post"> {% csrf_token %} <input type="submit"> </form> </body> </html>
day 96 CBV FBV 函数 类 restful --------------------- 好玩 有用 crm// restframework 基于django 框架开发得 https://www.cnblogs.com/yuanchenqi/articles/8715364.html 组合式得继承!! ---------------------- """ 类下得反射作得分发 cbv 得 本质 仍是一个 fbv url(r'^login/', views.LoginView.as_view()), def dispatch(self, request, *args, **kwargs): print('dispatch...') return super(LoginView, self).dispatch(request,*args, **kwargs) 执行父类; CBV 先后端 分离: 谷歌得一个插件, postman 模拟前端发 post 请求 https://www.getpostman.com/apps """ --------------------------
谷歌的一个插件,模拟前端发get post put delete请求,下载,安装。
https://www.getpostman.com/apps