MTV模型html
Django就是基於MTV模型的框架,其中: M:模型層 models.py T:templates V:視圖層 views
MVC模型前端
M:模型層 models V:視圖層 views C:控制器 controller
本質:django的MTV也是MVC
第一種:Django ORM自動幫建立ajax
class Book(models.Model): name = models.CharField(max_length=32) authors = models.ManyToManyField(to='Author') class Author(models.Model): name = models.CharField(max_length=32) # 多對多字段在任意一張表中均可以建立,通常建議在查詢頻率高的那張表中建 # 在Django中,上面的操做--指定Book與Author字段是多對多的關係,Django會自動建立兩者關係的表 # 好處是不用操心第三行表的建立 # 不足的地方在於,沒法在這張表中添加新的字段(只是本表的字段),只能是指定的這幾個關聯的字段
第二種:純手動建立第三張表django
class Book(models.Model): name = models.CharField(max_length=32) class Author(models.Model): name = models.CharField(max_length=32) class Book2Author(models.Model): book = models.ForeignKey(to='Book') author = models.ForeignKey(to='Author') info = models.CharField(max_length=32) # 手動新建第三張表,將該表中的幾個字段關聯到Book和Author表中 # 不足的地方在於不支持雙下劃線的反向查詢方式 # 好處在於擴展性大,能夠添加出來關聯的字段,還能夠添加這個表本身的字段
第三種:半自動建立第三張表json
class Book(models.Model): name = models.CharField(max_length=32) # 第三種建立表的方式 authors = models.ManyToManyField( to='Author',through='Book2Author',through_fields=('book','author')) class Author(models.Model): name = models.CharField(max_length=32) # book = models.ManyToManyField( to='Book',through='Book2Author',through_fields=('author','book')) class Book2Author(models.Model): book = models.ForeignKey(to='Book') author = models.ForeignKey(to='Author') info = models.CharField(max_length=32) # 一樣是要手動建立第三張表,像第二種方法那樣,一樣也須要操做第一種的方式,不過要添加參數 # 這樣建起來雖然麻煩了點,可是擴展性強的同時,又能夠經過點點點(基於對象/雙下劃線)來操做數據 # 使用第三種方式建立多對多關聯關係時,就不能使用set、add、remove、clear方法來管理多對多的關係了,只能經過第三張表的model來管理多對多關係
urlencodedbootstrap
Request Headers裏:Content-Type: application/x-www-form-urlencoded 前端對應的數據格式 name=tyft&password=23s3 後端獲取數據 request.POST ps: django會將urlencoded編碼的數據解析自動放到request.POST
multipart/form-data後端
form表單傳輸文件的編碼格式 後端獲取文件格式數據 request.FILES 後端獲取普通鍵值對數據 request.POST
application/jsonmvc
ajax發送json格式數據,數據在request.body中 須要注意的點 編碼與數據格式要一致
給個連接:http://www.javashuo.com/article/p-tubnhbxm-h.htmlapp
l = []
for i in range(10000): l.append(models.Book2(name='第%s本書'%i)) models.Book2.objects.bulk_create(l) # 批量插入數據
後端: book_list = models.Book2.objects.all() # 數據總條數 all_count = book_list.count() # 當前頁 current_page = request.GET.get('page',1) # 示例一個分頁器對象 page_obj = my_page.Pagination(current_page=current_page,all_count=all_count) # 對總數據進行切片 page_queryset = book_list[page_obj.start:page_obj.end] 前端: {{ page_obj.page_html|safe }} # 幫你渲染的是帶有bootstrap樣式的分頁器 # 直接導包用就好
l = []
for i in range(10000): l.append(models.Book2(name='第%s本書'%i)) models.Book2.objects.bulk_create(l) # 批量插入數據
後端: book_list = models.Book2.objects.all() # 數據總條數 all_count = book_list.count() # 當前頁 current_page = request.GET.get('page',1) # 示例一個分頁器對象 page_obj = my_page.Pagination(current_page=current_page,all_count=all_count) # 對總數據進行切片 page_queryset = book_list[page_obj.start:page_obj.end] 前端: {{ page_obj.page_html|safe }} # 幫你渲染的是帶有bootstrap樣式的分頁器 # 直接導包用就好
給個模板連接:http://www.javashuo.com/article/p-mrbwiwip-x.html