Django學習心得

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',) #添加時候的橫向選擇過濾(此處假設bookauthors 是多對多關係)
    raw_id_fields = ('publisher',) #添加時候的選擇(此處假設publisherbook是一對多關係)

admin.site.register(Publisher)
admin.site.register(Author,AuthorAdmin)
admin.site.register(Book,BookAdmin)

緩存機制

個人認爲緩存對一個訪問量過多的網站時非常重要的,Django裏面提供的緩存方式大致分爲三種:全站緩存配置方式,針對視圖緩存配置方式,針對數據緩存配置方式。只要修改相關配置文件即可。也可以裝其他插件來協助緩存,例如memcached。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章