django_视图层



视图层作用返回给展示层数据方便看的
他是通过路由层关系对应返回数据

一.视图层返回值

views.py 视图层
# 视图函数必须返回一个HttpResponse对象
已知返回对象的有三个分别为
render        # 返回 html文件
HttpResponse  # 返回 字符串
redirect      # 重定向 返回网址
通过查看源代码就知道


他返回的是HttpResponse

HttpResponse是一个类其他返回方式多继承罢了

二.返回值JsonResponse对象

'JsonResponse 属于 json 升级版'
from django thhp import Jsonrespones  

user_dict = {'name': 'jason', 'pwd': 123, 'hobby': '好好学习'}
# 1.返回这个字典
return JsonResponse(user_dict     # 不会解决文字会乱码
,json_dumps_params={'ensure_ascii':False})  序列化文字

# 2.通过JsonResponse返回列表
user_list = [11,22,33,44,55]  
return JsonResponse(user_list) # 报错
'return JsonResponse(user_list,asfe=False)' 

'django对json序列化的数据类型的范围做了扩充'	

三.通过from表单返回文件


前端html文件中修改的数据

# 对应的后端需使用request.FILES 方法获取到用户输入的文件名
可以with open 操作文件

四.request参数其他的方法

request.method          # 获取大写的请求值
request.POST            # 获取 POST请求 用户输入的数据
request.GET             # 获取 GET请求  用户输入的数据
request.FILES           # 获取用户传入的文件
request.body            # 原始二进制数据 以上方法都是从body解析出来的
request.path            # 获取路径
request.path_info       # 获取路径
request.get_full_path() # 获取路径并且还可以获取到路径后面携带的参数

五.FBV与CBV

FBV:基于函数的视图   # url(r'^index/',views.函数名)
'对应的是函数'
CBV:基于类的视图     # url(r'^cbv/',views.类名.as_view())
'对应的是类里的函数请求方式,'

from django import views
class User(views.View):
    def get(self,request):
        return HttpResponse('我是get')

    def post(self,request):
        return HttpResponse('我是post')

如果请求方式是GET 则会自动执行类里面的get方法
如果请求方式是POST 则会自动执行类里面的post方法

六.模板语法传值

"""
django提供的模板语法只有两个符号
	{{}}:主要用于变量相关操作(引用)
	{%%}:主要用于逻辑相关操作(循环、判断)
"""


1.传值的两种方式
	# 传值方式1:指名道姓的传  适用于数据量较少的情况       节省资源
  # return render(request, 'ab_temp.html', {'name':name})
  # 传值方式2:打包传值  适用于数据量较多的情况(偷懒)     浪费资源
  '''locals() 将当前名称空间中所有的名字全部传递给html页面'''
  return render(request, 'ab_temp.html', locals())

2.传值的范围
	基本数据类型都可以
  函数名
  	模板语法会自动加括号执行并将函数的返回值展示到页面上
    不支持传参(模板语法会自动忽略有参函数)
 	文件名
  	直接显示文件IO对象
  类名
  	自动加括号实例化成对象
  对象名
  	直接显示对象的地址 并且具备调用属性和方法的能力
  
# django模板语法针对容器类型的取值 只有一种方式>>>:句点符
	既可以点key也可以点索引  django内部自动识别
  	{{ data.index.inner.q1.img01 }}

7.CBV源码剖析

1.切入点:路由匹配
  类名点属性as_view并且还加了括号
  	as_view可能是普通的静态方法
    as_view可能是绑定给类的方法
2.对象查找属性的顺序
	先从对象自身开始、再从产生对象的类、之后是各个父类
  	MyLoginView.as_view()
    	先从我们自己写的MyLoginView中查找
     	没有再去父类Views中查找
3.函数名加括号执行优先级最高
	url(r'^ab_cbv/', views.MyLoginView.as_view())
  项目已启动就会执行as_view方法 查看源码返回了一个闭包函数名view
  def as_view(cls):
    def view(cls):
      pass
    return view
  url(r'^ab_cbv/', views.view)
  # CBV与FBV在路由匹配本质是一样的!!!
4.路由匹配成功之后执行view函数
	def view():
    self = cls()
    return self.dispatch(request, *args, **kwargs)
5.执行dispatch方法
	需要注意查找的顺序!!!
  def dispatch():
      handler = getattr(self, request.method.lower())
      return handler(request, *args, **kwargs)
"""查看源码也可以修改 但是尽量不要这么做 很容易产生bug"""
posted @ 2022-05-14 12:07  笑舞狂歌  阅读(36)  评论(0编辑  收藏  举报