虚拟环境、视图函数的返回值、JsonResponse对象、接收文件数据、FBV和CBV、模板语法传值

虚拟环境

django路由层版本区别

视图函数的返回值

JsonResponse对象

接收文件数据

FBV和CBV(基于函数的视图、基于类的视图)

CBV源剖析

模板语法传值

虚拟环境

# 我们在实际开发工作中,会针对不同的项目需要为其配备对应的解释器环境
eg:
    项目1 
    	django2.2 pymysql3.3 requests1.1
    项目2 
    	django1.1
    项目3
    	flask
# 怎样确保都能正常运行
   方式1:把所有需要用到的模块全部下载下来 如果有相同模块不同版本每次都重新下载替换
   方式2:提前准备好多个解释器环境 针对不同的项目切换即可
 
# 创建虚拟环境 
	相当于在下载一个全新的解释器
# 识别虚拟环境
	文件目录中有一个venv文件夹
# 如何切换环境
	选择不用的解释器即可 全文不要再次勾选new enviroment...

image-20220514211624622

django路由层版本区别

# 路由层
  Django1.x 和2.x  3.x有哪些区别
1、路由匹配的方法不一样
url()  支持正则    
path()第一个参数不支持正则,如果想要支持正则,我们就要使用
from django.urls import path,re_path

2、path方法提供了转换器功能
path('index/<int:id>/', index)
匹配对应位置的数据并且自动转换类型

image-20220515091935847

视图函数返回值

# 视图函数必须返回一个HttpResonse对象
# HttpResponse
class HttpResponse(...):
    pass

image-20220514222014945

# render
def render(...):
return HttpResponse(...)

image-20220514222243570

# redirect

def redirect(...):
# 多继承

image-20220514222335822

JsonResponse对象

user_dict = {'name': 'gavin', 'age': 20}
user_dict = {'name': 'gavin', 'age': 20, 'hobby': '上天'}
new_dict = json.dumps(user_dict)

乱码
{"name": "gavin", "age": 20, "hobby": "\u4e0a\u5929"}
ensure_ascii=False

image-20220514225107221

image-20220515092803220

 from django.http import JsonResponse
 user_dict = {'name': 'gavin', 'age': 20, 'hobby': '上天'}
    return JsonResponse(user_dict,json_dumps_params={'ensure_ascii': False})

image-20220514230121153

class JsonResponse(HttpResponse):
	def __init__(self, data,json_dumps_params=None, **kwargs):
		data = json.dumps(data, **json_dumps_params)
django对json序列化的数据类型的范围做了扩充

接收文件数据

# form表单上传文件
form表单上传的数据中如果含有文件 那么需要做以下几件事
# 只能拿到文件名<QueryDict: {'username': ['owen'], 'my_file': ['MySQL基础.md']}>

1.method必须是post
  2.enctype必须修改为multipart/form-data
  	默认是application/x-www-form-urlencoded
  3.后端需要使用request.FILES获取

<QueryDict: {'username': ['owen']}>
<MultiValueDict: {'my_file': [<InMemoryUploadedFile: 日志配置.md (application/octet-stream)>]}>
# 写入后端
        with open(file_obj.name,'wb') as f:
            for line in file_obj:
                f.write(line)

image-20220515100315292

  • request其他方法

request.method  
request.POST
request.GET
request.FILES

# request.body
	存放的是接收过来的最原始的二进制数据
# b'------WebKitFormBoundaryjkvuYsGZRAkd5O6J\r\nContent-Disposition: form-data; name="username"\r\n\r\nowen\r\n

 # request.POST、request.GET、request.FILES
   这些获取数据的方法其实都从body中获取数据并解析存放的

request.path
	获取路径
request.path_info
	获取路径
request.get_full_path()
	获取路径并且还可以获取到路径后面携带的参数
# 获取结果
/form_a/
/form_a/
/form_a/?name=gavin

FBV和CBV(基于函数的视图、基于类的视图

# FBV:基于函数的视图
url(r'^index/', views.index),

# CBV:基于类的视图
from django import views
class MyLoginView(views.View):
    def get(self,request):
        return HttpResponse('from  CBV  get')
    def post(self,request):
        return HttpResponse('from CBV post')
	url(r'^ab_cbv/', views.MyLoginView.as_view())
 	"""
 	如果请求方式是GET 则会自动执行类里面的get方法
 	如果请求方式是POST 则会自动执行类里面的post方法
 	"""

image-20220515103143797

image-20220515103411153

CBV源码剖析

# 切入点: 路由匹配
url(r'^CBV_a/', views.MyLoginView.as_view())
类名点属性as_view并且加了括号,所以
as_view 可能是普通的静态方法
as_view 可能是绑定给类的方法

# 独享查找属性的顺序
先从对象自身开始、再从产生对象的类、之后是各个父类
MyLoginView.as_view()
先从我们自己写的MyLoginView中查找
   没有再去父类Views中查找
   
# 函数名加括号执行优先级最高
url(r'^CBV_a/', views.MyLoginView.as_view())
项目已启动就会执行as_view方法 查看源码返回了一个闭包函数名view
  def as_view(cls):
    def view(cls):
      pass
    return view
所以也可以写成
url(r'^CBV_a/', views.view)

# 路由匹配成功之后执行view函数
def view():
    self = cls()
    return self.dispatch(request, *args, **kwargs)
# 我们也可以进行拦截,但是最好不要

# 执行dispatch方法
http_method_names = ['get', 'post', 'put', 'patch', 'delete', 'head', 'options', 'trace']
def dispatch():
      handler = getattr(self, request.method.lower())
      return handler(request, *args, **kwargs)

image-20220515115638052

image-20220515122106701

模板语法传值

"""
django提供的模板语法只有两个符号
	{{}}:主要用于变量相关操作(引用)
	{%%}:主要用于逻辑相关操作(循环、判断)
"""
# 1.传值的两种方式
传值方式1:指名道姓的传      节省资源
    name = 'gavin'
 return render(request, 'mb_a文件.html',{'name':name})
传值方式2:打包传值 适用于数据量较多的情况 浪费资源
return render(request, 'ab_temp.html', locals())
  '''locals() 将当前名称空间中所有的名字全部传递给html页面'''
    
# 2.传值的范围
	基本数据类型都可以
# 函数名
  	模板语法会自动加括号执行并将函数的返回值展示到页面上
    不支持传参(模板语法会自动忽略有参函数)
    def index(a):
        print('wuhu')
        return 'aihei'
文件名
  	直接显示文件IO对象
    <_io.BufferedWriter name='apps.py'>

类名
  	自动加括号实例化成对象
<app01.views.mb_a.<locals>.MyClass object at 0x00000189AB29D2E0>
对象名
  	直接显示对象的地址 并且具备调用属性和方法的能力


# django模板语法针对容器类型的取值 只有一种方式>>>:句点符
user_dict = {'info':{'pro':[123, 234, 345,{'name':'gavin','msg':'先帝创业未半,蹦迪超出预算'}]}}
    return render(request, 'mb_a文件.html',locals())
	既可以点key也可以点索引  django内部自动识别
  	{{ data1.info.pro.3.msg }}
posted @ 2022-05-15 12:56  未月  阅读(105)  评论(0编辑  收藏  举报