Django是python的web開發框架,遵循MVC的設計模式,但在Django中通常稱爲MTV(model-template-views)
。model是數據持久層,主要存放實體映射、實體關係以及實體的一些方法。template是表示層,主要是用來顯示數據,Django的視圖引擎可以將其渲染成HTML並顯示。views是業務邏輯層,在Django中充當着鏈接model與template的橋樑,處理模型並向template提交數據,同時也接受template的請求和參數,完成相應的邏輯後提交模型修改。
個人認爲這裏的MTV和.NET MVC表達的是同一個意思,最大的差別就是在.net裏views是表示層,而Django裏是業務邏輯層,根據官方文檔的意思只是對views的理解不一樣而已,其實完全可以當成controller來用。下面我將根據個人的一些理解來介紹一下Django的語法和特色。
1. views和URL
views是業務邏輯層,在Django裏面views通常是一個的views.py模塊,放在對應的包裏。views.py裏面是具體的邏輯函數,每一個函數對應着一個或多個模版,爲了建立模版與視圖的聯繫,還要有一定的路由機制,於是Django通常在根目錄有一個路由程序urls.py。路由由patterns來創建,用正則表達式來描述,極大地提高了路由機制的靈活性。
比如:
views.py
def home(request):
values = request.META.items()
values.sort()
return render_to_response('home.html',{"values":values})
urls.py
from django.conf.urls.defaults import *
urlpatterns = patterns('',('^$',home),)
在這裏request參數是必須的,但是你可以任意命名,只要符合規範即可,request包含頁面的請求信息。sender_to_response在django.shortcuts裏,所以你還要在前面聲明form django.shortcuts import sender_to_response。request.MATE裏含有所有的請求界面信息和用戶信息。shor()是對list從小到大排序。返回值的意思就是向home.html模版提交一個values變量。urls中patterns中的元組添加了正則的導向規則:除去原地址匹配'^$'者導向home。當然這前提是views.py文件與urls.py在同一個文件夾裏面否則就要引用home的命名空間。如果想在url中傳遞多個值,可以在你想傳遞的匹配值上面加上括號比如('^([^/]+)/([^/]+) /$',
home)就可以匹配/some/some/而some就會被傳到處理函數home。相應的home要添加適當的參數來接受。
模版(Template)
模版在Django中是顯示數據的地方,通常爲HTML格式,在模版中Django的處理邏輯要寫在{% %}中,而要顯示的變量要寫在{{ }}中。Django的母板頁可以用任何文檔充當,前提是要用{% block name %}{% endblock %}聲明要填充或替換的塊,而使用時只需{% extends 母版名字 %}然後調用相應的塊就可以了。
模型
在setting.py 中的database的字典中配置數據庫。配置完成後 使用manage.py startapp來創建app在models中編寫python代碼描述實體映射。比如:
models.py
class Publisher(models.Model):
name = models.CharField(max_length = 30)
website = models.URLField()
def __unicode__(self):
return self.name
class Meta:
ordering = ['name']
models包含在django.db中,裏面封裝了模型類的通用接口。CharField()是創建varchar型數據,參數有max_length,blank,verbose_name等。分別表示最大長度、是否爲空、顯示名稱。def__unicode__提供了裝箱後的默認顯示,如果沒有設置此函數,默認顯示object類型。class Meta規定了模型的默認排序字段。同時Django也提供了外鍵設置接口,此處以book爲例
class Book(models.Model):
title = models.CharField(max_length = 100)
authors = models.ManyToManyField(Author) #多對多關係
publisher = models.ForeignKey(Publisher) #多對一關係
publication_date = models.DateField(blank = True, null = True)
創建完成後要在setting.py配置文件INSTALL_APPS中加入app包的路徑。
Django支持codefirst 可以用manage.py syncdb來同步數據庫,更新數據庫時Django是先生成sql語句然後再執行,在執行前可以運行manage.py validate來檢查模型,也可以運行manage.py sqlall books。可以直接聲明模型對象來實現數據的插入save()保存 objects.filter()查找,可以對象調用delete()刪除,同時也可以模型調用delete批量刪除。同理update也是對象調用單個修改,模型調用批量修改。
集成的子框架
在django.contrib包中有多種附加功能包,目前只瞭解了admin和auth兩種感覺功能很強大,美中不足的是admin的界面略醜。 admin是Django官方提供的後臺管理平臺。可以管理你所添加的app集成了包括增刪改查在內的所有常用功能。調用代碼也很簡單,只需要在urls.py內激活admin的鏈接即可,配置文件在setting.py裏,有需求的話可以自行改動。如果想把app的管理加入裏面需要添加如下代碼(以Book爲例):
class BookAdmin(admin.ModelAdmin):
list_display = ('title', 'publisher', 'publication_date') #顯示順序
list_filter = ('publication_date',) #過濾列表
ate_hierarchy = 'publication_date' #激活列表上方的日期查詢
ordering = ('-publication_date',) #排序方式'-'代表倒序
filter_horizontal = ('authors',) #添加時候的橫向選擇過濾(此處假設book和authors 是多對多關係)
raw_id_fields = ('publisher',) #添加時候的選擇(此處假設publisher和book是一對多關係)
admin.site.register(Publisher)
admin.site.register(Author,AuthorAdmin)
admin.site.register(Book,BookAdmin)
緩存機制
個人認爲緩存對一個訪問量過多的網站時非常重要的,Django裏面提供的緩存方式大致分爲三種:全站緩存配置方式,針對視圖緩存配置方式,針對數據緩存配置方式。只要修改相關配置文件即可。也可以裝其他插件來協助緩存,例如memcached。