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