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要新增適當的引數來接受。
2. 模版(Template)
模版在Django中是顯示資料的地方,通常為HTML格式,在模版中Django的處理邏輯要寫在{% %}中,而要顯示的變數要寫在{{ }}中。Django的母板頁可以用任何文件充當,前提是要用{% block name %}{% endblock %}宣告要填充或替換的塊,而使用時只需{% extends 母版名字 %}然後呼叫相應的塊就可以了。
3. 模型
在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也是物件呼叫單個修改,模型呼叫批次修改。
4. 整合的子框架
在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)
5. 快取機制
個人認為快取對一個訪問量過多的網站時非常重要的,Django裡面提供的快取方式大致分為三種:全站快取配置方式,針對檢視快取配置方式,針對資料快取配置方式。只要修改相關配置檔案即可。也可以裝其他外掛來協助快取,例如memcached。