Skip to content

Latest commit

 

History

History
102 lines (71 loc) · 4.65 KB

06-first-view.md

File metadata and controls

102 lines (71 loc) · 4.65 KB

來幫網站加個首頁。因為這是 Django 教學,不是前端教學,所以這個範例會直接用 Bootstrap 拼一個簡單的介面。Django 本身不管前端,所以只要 Django 的部分做好,其他完全可以直接抽換,舉一反三應該不難。

當 Django 收到一個 HTTP request 時,會首先確認該 request 的 URI 應該對應到哪個 view(如果對應不到,直接回傳 404 Not Found),並把 request 交給它。View 要負責處理這個 request,並回傳一個 HTTP response:

           ┌──────────────┐
 request   │              │  response
─────────> │     view     │ ──────────>
           │              │
           └──────────────┘

這顯然是一個 function!所以在 Django 中,每個 view 其實就是一個 function。這個 function 接受一個 request 引數(與其他參數,我們之後會提到),回傳一個 django.http.HttpResponse 物件。由於 HTTP response 格式需要設定很多東西,所以 Django 提供了一個 shortcut django.shortcuts.render 來方便我們產出 response 物件。

所以我們來實作 home 這個 view。首先我們要在 lunch/urls.py 新增一個 URL pattern,讓 Django 知道如何把網址導向至 view 的 function:

from django.conf.urls import include, url
from django.contrib import admin
from stores.views import home

urlpatterns = [
    url(r'^$', home),
    url(r'^admin/', include(admin.site.urls)),
]

這個 url 用 regular expression match 首頁,也就是 URI 是空字串的狀況,並把它對應到 home

接著我們在 stores/views.py 實際實作 home function:

from django.shortcuts import render

def home(request):
    return render(request, 'home.html')

render 的第二個參數是 template 的位置(我們稍後會看到怎麼建立它)。render 會負責處理 template,產生一個合法的 HTML 檔案,並依此建立 HTTP response。

最後是 home.html。在 stores 裡建立一個目錄,叫做 templates,並在裡面新增 home.html

{# stores/templates/home.html #}

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>午餐系統</title>
<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css">
</head>

<body>
<nav class="navbar navbar-default navbar-static-top" role="navigation">
  <div class="container">
    <div class="navbar-header">
      <a class="navbar-brand" href="#">午餐系統</a>
    </div>
  </div>
</nav>
</body>
</html>

你可以看到,這基本上就是一個 HTML 檔案。render 會讀取這個檔案,並以它作為 content,建立 HTTP response。

再次 cd 到有 manage.py 的那一層,透過指令 python manage.py runserver 把 server 跑起來,然後打開 http://localhost:8000/ 看看。內容應該不再是 It works! 了,而是你剛剛放的 navbar。恭喜你完成了第一個 Django 頁面!

上面的 HTML 有一個小問題。我們沒有放午餐系統的連結。這個區塊應該要指向首頁,所以我們可以這樣寫:

<a class="navbar-brand" href="/">午餐系統</a>

但這不好。Django 不鼓勵你把 URL 直接寫死,因為如果你的網站之後要修改架構,更換所有的 URL 會很痛苦。我們真正想做的,其實不是讓它指向 /,而是指向 stores.views.home 對應的那個 URL,不管它是什麼。所以我們應該這麼做:

  1. 幫我們的 URL 加上一個名稱。

    lunch/urls.pyhome 的那行修改成下面這樣:

    url(r'^$', home, name='home'),
  2. 用這個 name 來 refer 我們要的 URL:

    <a class="navbar-brand" href="{% url 'home' %}">午餐系統</a>

等等!{% url 'home' %} 是什麼?

這叫 template tag。很顯然,你不能在 template 中寫 Python(all hail PHP!),所以如果你需要在 template 中使用任何邏輯(JavaScript 不算),就必須使用 template tags。

Django 的 template tag 語法是下面這樣:

{% tag_name [ argument ... ] %}

所以上面那個例子中,我們呼叫了 url 這個 tag,並傳入一個參數 'home'。這個 tag 會幫你找到名稱為 home 的 URL pattern(名稱就是 urls.py 裡的 name='home' ),並輸出該 pattern 對應的網址。在這裡,輸出的就會是 /

這就是你的第一個 Django view。接著我們要實際建立資料,把下面的內容也做出來。