CBV与FBV路由区别

urlpatterns = [
    url(r'^publish/$', views.Publishs.as_view()),  # CBV写法
    url(r'^publish/$', views.publish),    # FBV写法
]

我们通过看FBV的写法可以得知,这里写的是一个内存地址,路由匹配成功会自动执行

CBV写的是类.as_view(),加括号意味着在项目启动就会执行,那么我们大胆猜测,这里得到的也是一个函数地址。

我们来搂一眼源码:

Django中CBV   View的as_view()源码解析

果然,它返回了一个内存地址,而且是一个闭包函数

也就是说当路由匹配成功的时候会调用内部的view加括号

那我们需要进一步去看view里面干了些什么:

Django中CBV   View的as_view()源码解析

 

 

 我们发现它调用了dispatch方法,此时的self是我们的视图类对象,那么我们在查找dispatch方法时需要先从自身找,自身我们没有定义,那么此时就向父类找,最终在父类View里面找到了dispatch方法并调用

我们知道了它调用了dispatch方法,那我们来View里看看dispatch里面干了些什么:

Django中CBV   View的as_view()源码解析

 

 if 判断 请求方式是不是属于默认8大请求方式之一,如果是,通过反射,拿到self中定义的请求方法的函数地址

刚才我们说到,self是我们视图类的对象,那么这时候如果我们在视图类中定义了该请求方式同名的方法,那么就会走该方法。

 

 这个时候我们就应该有恍然大悟的感觉了,as_view()最终干的事情就是根据request请求方式来执行视图类的不同请求方法

 

相关文章:

  • 2021-12-13
  • 2021-08-09
  • 2019-02-23
  • 2022-12-23
  • 2022-01-12
  • 2018-07-31
  • 2021-09-15
猜你喜欢
  • 2021-06-20
  • 2021-07-09
  • 2018-08-24
  • 2021-11-28
  • 2022-02-18
  • 2021-09-02
  • 2021-11-14
相关资源
相似解决方案