查漏补缺

路由配置:

urls路由配置(正则,视图,xxx),还有第三个参数,用作反向解析:

浏览器配置:

当我们访问浏览器的时候:

有的时候url需要经常更新,在你的后台更新后那么在前端也要更新,少的话还好说,,多了那可就麻烦了,此时反向解析来了....


 

 render,redirect,HTTPresponse:

render返回渲染的模板;redirect跳转页面;HTTPresponse返回一个字符串;


 

 from django.template import Template,Context  ==  render方法:

context传值假如变量过多可以用local(),但是假如views有100个变量,模板中用1个,他会吧所有的值串过去。。。

深度查询:序列类型在前端可以通过"."的方式进行查找

过滤器:后端串过来的数据跟前端需要渲染的数据可能有细微的差别,此时就出现了过滤器{{name|filter}}

反向查询reverse:原本的查询结果四123,加上reverse之后就是321,颠倒了一下

过滤器:在应用下建templatetags文件,只能是这个文件名,在里边新建任意名字文件,setting中的App下边配置↓

模板中使用自定义的过滤器必须现在模板中导入:{{load xxx}}

自定义标签filter可以传两个{{ xx|filter }}变量;simple_tags可以传多个变量,放在{% simple_tag %}

传多个变量不能放在if 和for中;if可以跟在if 后边


 

查询的时候先分清他是queryset还是model,query必须转换为model对象才可以.出来东西

class Author(models.Model):
    '''作者表'''
    name = models.CharField(max_length=32)
    book = models.ManyToManyField(to="Book")
    def __str__(self):
        return self.name

class Book(models.Model):
    '''书表'''
    title = models.CharField(max_length=32)
    price = models.CharField(max_length=32)
    publish = models.ForeignKey(to="Publish")
    def __str__(self):
        return self.title
    #egon出版过的书的出版社信息

class Publish(models.Model):
    '''出版社'''
    address = models.CharField(max_length=32)
    def __str__(self):
        return self.address  

查询语法复习总结

# author = models.Author.objects.all()   #查询到所有的作者对象queryset   author多对多book
    # book = models.Book.objects.all()  # 查询到所有的书籍对象queryset       book多对一publish
    # publish = models.Publish.objects.all()   #查询到所有的出版社对象queryset
    # #================================================字段查询============================================================
    # for te in author:
    #     print("======author",te.name)      #查询自己表内的信息
    #     print("======author_book",te.book.first().title)      #通过自己查找多对多的字段
    #     print("======author_book_publish",te.book.first().publish.address)      #通过自己查找多对多的字段,然后查找多对一字段
    # for te in book:
    #     print("========tetetet",te)
    #     print("======book",te.title,te.price)      #查询自己表内的信息
    #     print("========book_publish",te.publish.address)     #通过自己查询多对一的出版社表
    #     print("==========book_author",te.author_set.first())     #通过自己反向查找作者姓名
    # for te in publish:
    #     print("=====publish",te.address)      #查询自己表内的信息
    #     print("=====publish_book",te.book_set.first().title)
    #     print("=======publish_book_author",te.book_set.first().author_set.first())
    #
    #
    # author_book_publish = author.first().book.all().first().title
    # print("==================================",author_book_publish)
    # #============================================双下划线正向查询===========================================================

    # author = models.Author.objects.all()  # 查询到所有的作者对象queryset   author多对多book
    # book = models.Book.objects.all()  # 查询到所有的书籍对象queryset       book多对一publish
    # publish = models.Publish.objects.all()  # 查询到所有的出版社对象queryset

    # book_title = author.filter(name="egon").values("book__title")      #在author表中查book标的title
    # book_price = author.filter(name="egon").values("book__price")      #在author表中查book表的price
    # book_publish_address = author.filter(name="egon").values("book__publish__address")   #在author表中二次关联查找出版社
    # print("============book_title|book_price",book_title,book_price)
    # print("============book_publish_addredd",book_publish_address)

    # #============================================双下划线反向查询===========================================================
    # book_title = publish.filter(address="北京").values("book__title")
    # book_price = publish.filter(address="北京").values("book__price")
    # publish_book = publish.filter(address="北京").values("book__author")
    # publish_author_book = publish.filter(address="北京").values("book__author__name")
    # print("============book_title|book_price",book_title,book_price)
    # print("============publish_book",publish_book)
    # print("============publish_author_book",publish_author_book)

    ########################################################################################################################

 

 

posted @ 2017-11-11 21:45  前方、有光  阅读(616)  评论(3编辑  收藏  举报