您現在所在的位置:首頁 >學習資源 > Python全棧+人工智能入門教材 > Python基礎入門教程72:實現視圖

Python基礎入門教程72:實現視圖

來源:奇酷教育 發表于:

實現視圖視圖是一個簡單的 Python 方法,它接受一個請求對象,負責實現:任何業務邏輯(直接或間接)上下文字典,它包含模板數據使用一個

實現視圖

視圖是一個簡單的 Python 方法,它接受一個請求對象,負責實現:

  • 任何業務邏輯(直接或間接)
  • 上下文字典,它包含模板數據
  • 使用一個上下文來表示模板
  • 響應對象,它將所表示的結果返回到這個框架中

在 Django 中,當一個 URL 被請求時,所調用的 Python 方法稱為一個視圖(view),這個視圖所加載并呈現的頁面稱為模板(template)。由于這個原因,Django 小組將 Django 稱為一個 MVT(model-view-template)框架。另一方面,TurboGears 把自己的方法稱作控制器(controller),將所呈現的模板稱為視圖(view),因此縮寫也是 MVC。其區別在于廣義的語義,因為它們所實現的內容是相同的。

最簡單的視圖可能會返回一個使用字符串初始化過的 HttpResponse 對象。創建下面的方法,并生成一個 /jobs HTTP 請求,以確保 urls.py 和 views.py 文件都已經正確設置。

清單 25. jobs/views.py (v1)
1
2
3
4
from django.utils.httpwrappers import HttpResponse
 
def index(request):
    return HttpResponse("Job Index View")

下面的代碼將獲取最近的 10 個職位,并通過一個模板呈現出來,然后返回響應。沒有 下一節 中的模板文件,這段代碼就無法 正常工作。

清單 26. jobs/views.py (v2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
from django.template import Context, loader
from django.http import HttpResponse
from jobs.models import Job
 
from django.template import Context, loader
from django.http import HttpResponse
from jobs.models import Job
 
def index(request):
    object_list = Job.objects.order_by('-pub_date')[:10]
    t = loader.get_template('jobs/job_list.html')
    c = Context({
        'object_list': object_list,
    })
    return HttpResponse(t.render(c))

在上面的代碼中,模板是由 jobs/job_list.html 字符串進行命名的。該模板是使用名為 object_list的職位列表的上下文呈現的。所呈現的模板字符串隨后被傳遞到 HTTPResponse 構造器中,后者通過這個框架被發送回請求客戶機那里。

加載模板、創建內容以及返回新響應對象的步驟在下面都被 render_to_response 方法取代了。新增內容是詳細視圖方法使用了一個 get_object_or_404 方法,通過該方法使用所提供的參數獲取一個 Job 對象。如果沒有找到這個對象,就會觸發 404 異常。這兩個方法減少了很多 Web 應用程序中的樣板代碼。

清單 27. jobs/views.py (v3)
1
2
3
4
5
6
7
8
9
10
11
12
from django.shortcuts import get_object_or_404, render_to_response
from jobs.models import Job
 
def index(request):
    object_list = Job.objects.order_by('-pub_date')[:10]
    return render_to_response('jobs/job_list.html',
                              {'object_list': object_list})
 
def detail(request, object_id):
    job = get_object_or_404(Job, pk=object_id)
    return render_to_response('jobs/job_detail.html',
                              {'object': job})

注意,detail 使用 object_id 作為一個參數。這是前面提到過的 jobs urls.py 文件中 /jobs/ URL 路徑后面的數字。它以后會作為主鍵(pk)傳遞給 get_object_or_404 方法。

上面的視圖仍然會失敗,因為它們所加載和呈現的模板(jobs/job_list.html and jobs/job_detail.html)不存在。

主站蜘蛛池模板: 亚洲va欧美va国产综合| 伊人成年综合网| 97久久综合精品久久久综合| 涩涩色中文综合亚洲| 久久综合给合久久狠狠狠97色| 色婷婷久久综合中文久久一本| 天天做天天爱天天爽综合网| 狠狠色狠狠色综合日日不卡| 亚洲综合色在线观看亚洲| 久久亚洲高清综合| 五月天综合色激情| 久久精品桃花综合| 伊人久久大香线蕉综合影院首页| 狠狠色丁香久久婷婷综合蜜芽五月| 狠色狠色狠狠色综合久久| 狠狠色综合色综合网络| 伊人久久大香线焦AV综合影院| 亚洲综合精品网站在线观看| 一本一本久久A久久综合精品| 久久综合狠狠综合久久综合88| 亚洲精品二区国产综合野狼| 国产成人综合洲欧美在线 | 久久久久久久综合日本亚洲| 色综合天天综合网国产成人网| 国产色婷婷精品综合在线| 色婷婷综合久久久久中文字幕| 久久青青草原综合伊人| 亚洲AV人无码综合在线观看 | senima亚洲综合美女图| 亚洲综合偷自成人网第页色| 亚洲伊人久久综合影院| 久久综合给合久久狠狠狠97色69| 狠狠色噜狠狠狠狠色综合久| 亚洲综合国产一区二区三区| 少妇人妻综合久久中文字幕| 色综合中文综合网| 狠狠色丁香婷婷久久综合| 色婷婷综合久久久久中文一区二区| 狠狠色伊人亚洲综合网站色| 亚洲综合国产精品| 久久综合给久久狠狠97色|