Django中 render() 函數的使用方法

render() 函數

在講 render() 函數之前,我們在 Django 項目 index 文件夾的 urls.py 和 views.py 中編寫如下功能代碼:(不難,望讀者細心閱之)

# index的 urls.py
from django.urls import path
form . import views

urlpatterns = [
    # 定義首頁的路由
    path(' ', views.index, name='index'),
]    
# index的views.py
from django.http import HttpResponse
def index(request):
    html = '<h1> Hello World </h1>'
    return HttpResponse(html, status=200)

視圖函數 index 使用響應類 HttpResponse 實現響應過程。從 HttpResponse 的參數可知,第一個參數是響應內容,一般是網頁內容或 JSON 數據,網頁內容是以HTML語言為主的,JSON數據用於生成API接口數據。第二個參數用於設置HTTP狀態碼,它支持HTTP所有的狀態碼。

從源碼角度分析,打開響應類 HttpResponse 的源碼文件,發現 Django內置的響應類(本人在上篇文章中已講過)都是在 HttpResponse 的基礎上實現的,只不過它們的HTTP狀態碼有所不同,如圖下所示。

從 HttpResponse 的使用過程可知,如果要生成網頁內容,就需要將 HTML 語言以 字符串的形式表示,如果網頁內容過大,就會增加視圖函數的代碼量,同時也沒有體現模板的作用,因此Django在此基礎上進行了封裝處理,定義了函數 render redirect
render()語法如下:

render(request, template_name, context=None, content_type=None, status=None, using=None)

render 的參數 request 和 template name 是必需參數,其餘的參數是可選參數。各個參數說明如下。

  • request:瀏覽器向服務器發送的請求對象,包含用戶信息、請求內容和請求方式等。
  • template_name:設重模板文件名,用於生成網頁內容。
  • context:對模板上下文(模板變量)賦值,以字典格式表示,默認情況下是一個空字典。
  • content_type:響應內容的數據格式,一般情況下使用默認值即可。
  • status:HTTP狀態碼,默認為200。
  • using:設置模板引擎,用於解析模板文件,生成網頁內容。

為了更好地說明 render 的使用方法,我們通過簡單的例子來加以說明。在Django項目的index文件中的 views.py 和 templates 的 index.html 中編寫以下代碼:

# index的 views.py
from django.shortcuts import render
def index(request):
    value = {'title': 'Hello Django'}
    return render(request, 'index.html', context=value)
# templates 的 index.html
<!DOCTYPE html>
<html>
  <body>
    <h3> {{ title }} </h3>
  </body>
</html>

視圖函數 index 定義的變量 value 作為 render 的參數 context,而模板 index.html 里通過使用模板上下文(模板變量){{ title }} 來獲取變量 value 的數據,上下文的命名必須與變量 value 的數據命名(字典的key)相同,這樣 Django 內置的模板引擎才能將參數context(變量value)的數據與模板上下文進行配對,從而將參數 context 的數據轉換成網頁內容。運行Django項目,在瀏覽器上訪問127.0.0.1:8000即可看到網頁信息,如圖下所示。

 

希望以上內容能夠幫助到各位!