CBV源码剖析

你自己不要修改源码 除了bug很难找

突破口在urls.py

url(r'^login/',views.MyLogin.as_view())

url(r'^login/',views.view) FBV一模一样

CBV与FBV在路由匹配上本质是一样的 都是路由 对应 函数内存地址

"""
函数名/方法名 加括号执行优先级最高
猜测
as_view()
要么是被@staicmethod修饰的静态方法
要么是被@classmethod修饰的类方法 正确

@classonlymethod
def as_view(cls, **initkwargs):
    pass

"""

@classonlymethod
def as_view(cls, **initkwargs):
    """
    cls就是我们自己写的类   MyCBV
    Main entry point for a request-response process.
    """
    def view(request, *args, **kwargs):
        self = cls(**initkwargs)  # cls是我们自己写的类
        # self = MyLogin(**initkwargs)  产生一个我们自己写的类的对象
        return self.dispatch(request, *args, **kwargs)
        """
        以后你们会经常需要看源码 但是在看python源码的时候 一定要时刻提醒自己面向对象属性方法查找顺序
            先从对象自己找
            再去产生对象的类里面找
            之后再去父类找
            ...
        总结:看源码只要看到了self点一个东西 一定要问你自己当前这个self到底是谁
        """
    return view
  
	# CBV的精髓
def dispatch(self, request, *args, **kwargs):
    # 获取当前请求的小写格式 然后比对当前请求方式是否合法
    # get请求为例
    # post请求
    if request.method.lower() in self.http_method_names:
        handler = getattr(self, request.method.lower(), self.http_method_not_allowed)
        """
        反射:通过字符串来操作对象的属性或者方法
            handler = getattr(自己写的类产生的对象,'get',当找不到get属性或者方法的时候就会用第三个参数)
            handler = 我们自己写的类里面的get方法
        """
    else:
        handler = self.http_method_not_allowed
    return handler(request, *args, **kwargs)
    """
    自动调用get方法
    """

要求掌握到不看源码也能够描述出CBV的内部执行流程(******)

posted @   shclbear  阅读(91)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
点击右上角即可分享
微信分享提示