目錄
-
虛擬環境
-
django路由層版本區別
-
檢視函式返回值
-
JsonResponse物件
-
上傳檔案
-
request方法
-
FBV與CBV
-
CBV源剖析
-
模板語法傳值
內容
虛擬環境
我們在實際開發工作中,針對不同的專案需要為其配備對應的直譯器環境
諸多專案在你的機器上如何無障礙的開啟並執行
- 方式1:把所有需要用到的模組全部下載下來,如果有相同模組不同版本每次都重新下載替換
- 方式2:提前準備好多個直譯器環境,針對不同的專案切換即可
建立虛擬環境:相當於下載一個全新的直譯器
識別虛擬環境:檔案目錄中有一個venv資料夾
如何切換環境:選擇不用的直譯器即可,不要再次勾選new enviroment...
django版本區別
路由層
django1.x與2.x、3.x有些許區別
路由匹配的方法不一樣
- url():支援正則
- path():第一個引數不支援正則,寫什麼是什麼
如果想使用正則,也提供了方法
from django.urls import path,re_path re_path(r'^index/', index)
path方法提供了轉換器功能
path('index/<int_id>/', index)
匹配對應位置的資料並且自動轉換型別
有五種轉換器可供選擇
檢視函式返回值
檢視函式必須返回一個HttpResonse物件
HttpResponse
render
redirect(多繼承)
JsonResponse物件
user_dict = {'name': 'zhou', 'pwd': 123, 'hobby': '好好學習'} return JsonResponse(user_dict,json_dumps_params={'ensure_ascii':False})
如果序列化的不是字典
user_list = [11,22,33,44,55]
return JsonResponse(user_list,safe=False)
為什麼使用JsonResponse而不是原始的json模組,因為django對json序列化的資料型別的範圍做了擴充
上傳檔案
form表單上傳的資料中如果含有檔案,那麼需要做以下幾件事
- method必須是post
- enctype必須修改為multipart/form-data 預設是application/x-www-form-urlencoded
- 後端需要使用request.FILES獲取(POST只會拿到檔名)
file_obj = request.FILES.get('my_file')
print(file_obj.name):檢視檔名
上傳檔案(支援for迴圈)
with open(file_obj.name,'wb') as f: for line in file_obj: f.write(line)
django會根據資料型別的不同自動幫你封裝到不同的方法中
request方法
- request.method
- request.POST
- request.GET
- request.FILES
- request.body:存放的是接收過來的最原始的二進位制資料,request.POST、request.GET、request.FILES這些獲取資料的方法其實都是從body中獲取資料並解析存放的
- request.path:獲取路徑
- request.path_info:獲取路徑
- request.get_full_path():獲取路徑並且還可以獲取到路徑後面攜帶的引數
FBV與CBV
FBV:基於函式的檢視
url(r'^index/',函式名)
CBV:基於類的檢視
from django import views class MyLoginView(views.View): def get(self, request): return HttpResponse("from CBV get view") def post(self, request): return HttpResponse("from CBV post view")
url(r'^ab_cbv/',views.MyLoginView.as_view())
如果請求方式是GET,則會自動執行類裡面的get方法
如果請求方式是POST 則會自動執行類裡面的post方法
切入點:路由匹配
類名點屬性as_view並且還加了括號
as_view可能是普通的靜態方法,as_view可能是繫結給類的方法
物件查詢屬性的順序
先從物件自身開始,再從產生物件的類,之後是各個父類
MyLoginView.as_view():先從我們自己寫的MyLoginView中查詢,沒有再去父類Views中查詢
函式名加括號執行優先順序最高
url(r'^ab_cbv/', views.MyLoginView.as_view())
專案一啟動就會執行as_view方法,檢視原始碼發現返回了一個閉包函式名view
== url(r'^ab_cbv/', views.view)
CBV與FBV在路由匹配本質是一樣的
路由匹配成功之後執行view函式
執行dispatch方法(需要注意查詢的順序)
模板語法傳值
django提供的模板語法只有兩個符號
- {{ }}:主要用於變數相關操作(引用)
- {% %}:主要用於邏輯相關操作(迴圈、判斷)
傳值的兩種方式
傳值方式1:指名道姓的傳,適用於資料量較少的情況,節省資源
return render(request,'ab_temp.html',{'name':name})
傳值方式2:打包傳值,適用於資料量較多的情況,浪費資源
return render(request, 'ab_temp.html', locals())
locals() 將當前名稱空間中所有的名字全部傳遞給html頁面
2.傳值的範圍
- 基本資料型別都可以
- 函式名:模板語法會自動加括號執行並將函式的返回值展示到頁面上,但是不支援傳參(模板語法會自動忽略有參函式)
- 檔名:直接顯示檔案IO物件
- 類名:自動加括號例項化成物件
- 物件名:直接顯示物件的地址,並且具備呼叫屬性和方法的能力
django模板語法針對容器型別的取值只有一種方式>>>:句點符 既可以點key也可以點索引,django內部自動識別