执行顺序 : Admin
- 执行admin.py,导入models
第一次进来的时候,先创建admin.site对象(如果下次再有引入,不会重新创建)
- 拿到对象后执行该对象下的register()方法
- 目的是将 注册的类 添加到_registry{}中
- admin.site是实例化AdminSite的对象
- 实例化完成后,执行__init__方法
- 拿到一个_registry = {}
- 再看AdminSite类下的register()方法,里面执行的是啥?
- register()可以传进两个参数,第二个参数默认为None
- 如果我们自己定义了一个RoleConfig(admin.ModelAdmin):类, 它会优先调用自定义的类.
- 调用register后.会传进去一个_registry
- 你注册一个它就会在_registry里面生成一个键值对
- _registry = {
models.Role : ModelAdmin(models.Role,admin.site),
}
- _registry = {
models.Role : RoleConfig(models.Role,admin.site),
} // 它会调用内部的一个 list_display
- 咱们综上所有都是为了生成 _registry 这个字典
=====================================================================================
接下来,通过我们访问admin 可以看到.
- 注册过的每一张表,都生成若干张表.在这里咱们默认为 增删改查四张表
- 请求过来后,咱们应该执行视图.
- 当运行程序时,
- 会先找到每一个APP中的admin.py文件,并加载(记得要注册哦)
- 创建admin.site中的对象,执行register方法.
- 接下来来到urls,在此处执行如图. 再次调用admin.site的urls
- 这个urls看起来是个属性对不对. 别急…给你图
- 看到@property没
- 伪造成属性,其实它的本质是个方法哦
- 看它的返回值,三个参数用逗号隔开. 它其实就是返回了一个元组.
- 该元组下,有三个参数,第一个参数是个函数. 我们点进去看看
- 由此可见, 第一个元素返回了一个列表
- 手动展示一下
- 接下来我们来看看这个列表是个啥?
05-11 21:47