stark组件3_filter过滤-创新互联

过滤项

在配置类中定义,title字段没什么意义,这次仅作演示用

创新互联是一家集网站建设,麻栗坡企业网站建设,麻栗坡品牌网站建设,网站定制,麻栗坡网站建设报价,网络营销,网络优化,麻栗坡网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
list_filter = ["title", "publish", "authors"]

调用和取数据

调用:

filter_condition = self.get_filter_condition(request)

取出数据:
连续两个filter之间是且的关系,等于取出符合这两个条件的数据

data_list = self.model.objects.all().filter(search_condition).filter(filter_condition)

处理逻辑

def get_filter_linktag(self):
    link_dic = {}

    #--------------------数据处理逻辑-------------------------
    #循环过滤项列表
    for filter_field in self.config.list_filter: #["title", "publish", "authors"]

        #获取request.GET中相应是哪个字段
        #举例:http://127.0.0.1:8000/stark/app01/book/?publish=2
        #当循环到publish时获取这个2
        cid = self.request.GET.get(filter_field, 0)

        #根据字符串名称拿字段对象,self.config是当前这张表的配置类实例对象
        filter_field_obj = self.config.model._meta.get_field(filter_field)
        #print("filter_field_obj==>", filter_field_obj)
        #得到app01.Book.publish和app01.Book.authors

        #拿对象下面的数据
        #.rel .to 来自于ForeignKey和ManyToManyField这两个类
        #.rel可以看到对象的数据类型,加上.to可以拿到对象下面的数据,.to只对一对一,一对多,多对多有效
        #print(filter_field_obj.rel.to)
        #结果:
        #< class 'app01.models.Publish'>
        #< class 'app01.models.Author'>

        #判断当前字段对象是不是一对多或多对多类型(需要提前引入这两个类),两种情况取得值也有所不懂
        if isinstance(filter_field_obj, ForeignKey) or isinstance(filter_field_obj, ManyToManyField):
            #如果是的话就取这个字段关联的内容
            data_list = filter_field_obj.rel.to.objects.all() #[publish2, publish3....]
            # print("data_list==>", data_list)
            # < QuerySet[ < Publish: 图灵新知 >, < Publish: dzm >, < Publish: 老男孩出版社 >] >
            # < QuerySet[ < Author: egon >, < Author: alex >] >
        else:#如果不是的话直接取字段对象的内容,这里只取主键和当前filter_field的值,比如当前正好是"title"
            data_list = self.config.model.objects.all().values("pk", filter_field)
            #print("data_list==>", data_list)
            #data_list==> ALL" %params.urlencode()))
        else: #如果没有值     
            temp.append(mark_safe("ALL"))

        #处理数据标签
        #将data_list循环起来 < QuerySet[ < Publish: 图灵新知 >, < Publish: dzm >...] >
        for obj in data_list:
            #判断当前字段对象是不是一对多或多对多
            if isinstance(filter_field_obj, ForeignKey) or isinstance(filter_field_obj, ManyToManyField):
                #此时的obj是一个个对象,取主键值和文本内容
                pk = obj.pk
                text = str(obj) #图灵新知
                params[filter_field] = pk #结果
            else: #如果不是
                #此时的obj是QuerySet{'pk': 10, 'title': 'PHP'}
                pk = obj.get("pk")
                text = obj.get(filter_field)
                params[filter_field] = text

            #params里面是QueryDict(),所以要做序列化
            _url = params.urlencode()

            #给选中内容加高亮
            if cid == str(pk) or cid == text:
                link_tag = "%s" % (_url, text)
            else:
                link_tag = "%s" % (_url, text)
            #添加到temp列表
            temp.append(mark_safe(link_tag))

        #构建字典用作返回
        link_dic[filter_field] = temp
        #{'publish': ["ALL", "图灵新知"...

    return link_dic

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前文章:stark组件3_filter过滤-创新互联
当前链接:http://scyanting.com/article/cegggg.html