前端关联 组合过滤查询

实现效果如图:

models.py 创建表代码

from django.db import models

# Create your models here.

class Level(models.Model):
name = models.CharField(max_length=32) def __str__(self):
return self.name # 方向
class Direction(models.Model):
name = models.CharField(max_length=32)
d_2_c = models.ManyToManyField('Category') def __str__(self):
return self.name # 类型
class Category(models.Model):
name = models.CharField(max_length=32)
def __str__(self):
return self.name # #反向
# models.Category.objects.filter(Direction__id =id)
# # 正向
# models.Direction.objects.filter(id = id).d_2_c.all() class Video(models.Model):
lv = models.ForeignKey(Level)
cg = models.ForeignKey(Category) title = models.CharField(verbose_name='标题', max_length=32)
summary = models.CharField(verbose_name='简介', max_length=32)
img = models.ImageField(verbose_name='图片', upload_to='./static/images/Video/')
href = models.CharField(verbose_name='视频地址', max_length=256) create_date = models.DateTimeField(auto_now_add=True)
def __str__(self):
return self.title

urls.py路由分发代码

from django.conf.urls import url
from django.contrib import admin
from app01 import views urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^video-(?P<dr_id>\d+)-(?P<cg_id>\d+)-(?P<lv_id>\d+).html',views.video,name='vvv2'),
]

views.py视图函数代码

from django.shortcuts import render
from app01 import models # Create your views here.
def video(request,*args,**kwargs):
# 0-0-0.html
# 0-1-0.html
# 1-0-0.html
# 1-1-0.html [1,2,3,4]
# 2-1-0.html [2,3,4]
dr_id = kwargs.get('dr_id')
cg_id = kwargs.get('cg_id')
lv_id = kwargs.get('lv_id')
condition = {} drection_list = models.Direction.objects.all()
level_list = models.Level.objects.all() if dr_id == "0":
# 未选择方向
category_list = models.Category.objects.all()
if cg_id == '0':
# 未选择分类
pass
else:
# 选择分类
# models.Video.objects.filter(cg_id=cg_id)
condition['cg_id'] = cg_id
else:
# 选择了方向
category_list = models.Category.objects.filter(direction=dr_id) temp = category_list.values_list('id')
cg_id_list = list(zip(*temp))[0] if cg_id == '0':
# 未选择分类
condition['cg_id__in'] = cg_id_list
else:
# 选择了分类
if int(cg_id) in cg_id_list:
condition['cg_id'] = cg_id
else:
condition['cg_id__in'] = cg_id_list
kwargs['cg_id'] = '0' if lv_id == '0':
pass
else:
condition['lv_id'] = lv_id result = models.Video.objects.filter(**condition)
print(result) return render(request, 'video.html', {
'drection_list': drection_list,
'level_list': level_list,
'category_list': category_list,
'arg_dict': kwargs,
'result':result,
})

自定义标签 templatetags xx.py代码

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Date : 2017/2/6
# @Author : Jesson
# @Blog : http://www.cnblogs.com/hellojesson/
#
from django import template
from django.utils.safestring import mark_safe
register = template.Library() # 方向
@register.simple_tag
def dr_tag(obj,arg_dict):
"""
生成A标签
:param obj:
:param arg_dict:
:return:
"""
from django.urls import reverse url = reverse('vvv2', kwargs={'dr_id': obj.id, 'cg_id': arg_dict.get('cg_id'), 'lv_id': arg_dict.get('lv_id')}) if str(obj.id) == arg_dict.get('dr_id'):
# 获取当前URL
tag = "%s" %(url,obj.name)
return mark_safe(tag)
else:
tag = "%s" % (url, obj.name)
return mark_safe(tag) # 类别
@register.simple_tag
def cg_tag(obj,arg_dict):
from django.urls import reverse url = reverse('vvv2', kwargs={'dr_id': arg_dict.get('dr_id'), 'cg_id': obj.id, 'lv_id': arg_dict.get('lv_id')}) if str(obj.id) == arg_dict.get('cg_id'):
# 获取当前URL
tag = "%s" %(url,obj.name)
return mark_safe(tag)
else:
tag = "%s" % (url, obj.name)
return mark_safe(tag) # 难度级别
@register.simple_tag
def lv_tag(obj,arg_dict):
from django.urls import reverse url = reverse('vvv2', kwargs={'dr_id': arg_dict.get('dr_id'), 'cg_id': arg_dict.get('cg_id'), 'lv_id': obj.id}) if str(obj.id) == arg_dict.get('lv_id'):
# 获取当前URL
tag = "%s" %(url,obj.name)
return mark_safe(tag)
else:
tag = "%s" % (url, obj.name)
return mark_safe(tag) # 全部显示
@register.simple_tag
def total_tag_2(arg_dict,key):
from django.urls import reverse
if key == 'dr_id':
url = reverse('vvv2', kwargs={'dr_id': 0, 'cg_id': arg_dict.get('cg_id'), 'lv_id': arg_dict.get('lv_id')})
elif key == 'cg_id':
url = reverse('vvv2', kwargs={'dr_id': arg_dict.get('dr_id'), 'cg_id': 0, 'lv_id': arg_dict.get('lv_id')}) elif key == 'lv_id':
url = reverse('vvv2', kwargs={'dr_id': arg_dict.get('dr_id'), 'cg_id': arg_dict.get('cg_id'), 'lv_id': 0})
else:
url = ''
if arg_dict.get(key) == '0':
tag = "全部" % (url,)
else:
tag = "全部" % (url,)
return mark_safe(tag)

前端video.html 代码

{% load xx %}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
.filter {
background-color: #EFEFEF;
line-height: 20px;
margin-top: 20px;
}
.filter a{
display: inline-block;
text-decoration:none;
margin: 5px;
padding: 3px 5px;
}
.filter a.active{
background-color: brown;
color: white;
}
</style>
</head>
<body>
<h2>筛选条件</h2>
<div class="filter">
<div>
<a>方向:</a>
{% total_tag_2 arg_dict 'dr_id' %}
{% for item in drection_list %}
<!-- if判断,如果kwargs.dr_id = item.id
- 加入样式
else:
- 无样式
-->
{% dr_tag item arg_dict %}
{% endfor %} </div>
<div>
<a>分类:</a>
{% total_tag_2 arg_dict 'cg_id' %}
{% for item in category_list %}
{% cg_tag item arg_dict %}
{% endfor %}
</div>
<div>
<a>难度:</a>
{% total_tag_2 arg_dict 'lv_id' %}
{% for item in level_list %}
{% lv_tag item arg_dict %}
{% endfor %}
</div>
</div> <h2>查询结果</h2>
<div class="content">
{% for row in result %}
<div style="width: 100px;height: 260px;float: left;margin: 3px;">
<img style="width: 100px;height: 150px;" src="{{ row.img }}">
<p>{{ row.title }}</p>
<p>{{ row.summary }}</p>
</div>
{% endfor %}
</div>
</body>
</html>

Django模版语言自定义标签-实现前端 关联组合过滤查询的更多相关文章

  1. Django模版语言的复用 1. include标签--模版导入 2.inclusion_tag自定义标签--模版导入 3.母版

    include标签--模版导入 ''' 前提:项目中,往往会出现多个页面拥有一个或几个相同的页面版块,或是一个页面多个页面版块是相同的 如何运用:可以将多个样式标签的集合进行封装,对外提供版块的名字( ...

  2. Django模版语言 格式化显示 后台datatime()时间

    Django模版语言 格式化显示 后台datatime()时间 场景描述:

  3. Django(模板语言-自定义filter和simple_tag)

    Django(模板语言-自定义filter和simple_tag)   filter过滤器的主要形式:变量|函数,意思是将变量交给函数处理,而自定义filter就是自己定义函数,因为用到已有的很少. ...

  4. Django 模版语言详解

    一.简介 模版是纯文本文件.它可以产生任何基于文本的的格式(HTML,XML,CSV等等). 模版包括在使用时会被值替换掉的 变量,和控制模版逻辑的 标签. 例: {% extends "b ...

  5. Django模板语言,标签整理

    Django模板语言 标签 内置标签引用 1. autoescape 控制自动转义是否可用. 这种标签带有任何 on 或 off 作为参数的话,他将决定转义块内效果. 该标签会以一个endautoes ...

  6. Django 模版语言

    传入变量 {{ 变量名 }} 在 view.py 的函数返回 render 时在html文件名后传入一个字典,字典的 key 对应html文件中的变量名,value 为传入的值 views.py: d ...

  7. Jinja2模版语言自定义filter的使用

    Jinja2模版语言,自带有一些filter,能够在前端的模版中控制数据按照相应的方式显示.比如以下两种filter,分别能在前端控制数字的近似精度显示和根据字符串长度补齐: round(value, ...

  8. django -- 模版语言之过滤器Filters和for循环

    前戏 在前面写的图书管理系统中,我们对模版语言应该已经不陌生了,使用{{ }}包裹起来的就是模版语言,只需要记住两种就可以了 {{ 变量名 }}            变量相关的 {% %}      ...

  9. 在django中使用自定义标签实现分页功能

    效果演示: github地址:https://github.com/mncu/django_projects/tree/master/django_projects/pagination_test 本 ...

随机推荐

  1. Codeforces Round #517 (Div. 2, based on Technocup 2019 Elimination Round 2) D. Minimum path(字典序)

    https://codeforces.com/contest/1072/problem/D 题意 给你一个n*n充满小写字母的矩阵,你可以更改任意k个格子的字符,然后输出字典序最小的从[1,1]到[n ...

  2. TCP/IP协议(3):数据链路层

    OSI数据链路层上的协议有Ethernet/IEEE802.3/IEEE802.4/IEEE802.5. ARP.RARP等. 1.Ethernet(以太网) 链路层支持很多协议,比如Ethernet ...

  3. Architecture

    SMART Crossbar The SMART crossbar is the primary building block in a SMART NoC that enables straight ...

  4. warning: rpmts_HdrFromFdno: Header V4 DSA/SHA1 Signature, key ID 192a7d7d: NOKEY

    症状描述: 使用yum安装软件时报如下错误: warning: rpmts_HdrFromFdno: Header V4 DSA/SHA1 Signature, key ID 192a7d7d: NO ...

  5. 学以致用四----centos7.2 安装python3.6

    基础配置弄好后,开始搭建环境 本次的目的是安装 python 3.6 一.安装相关的依赖包 在之前的博客里有安装python3.6的步骤,为了避免做重复的步骤.需事先准备好依赖包 yum instal ...

  6. memcache和redis本质区别在哪里?

    转自:http://www.dewen.org/q/971/memcache%E5%92%8Credis%E6%9C%AC%E8%B4%A8%E5%8C%BA%E5%88%AB%E5%9C%A8%E5 ...

  7. Html5与Css3知识点拾遗(二)

    页面title 选择能简要概括文档内容的文字作为title文字,title核心内容放在前60个字符 分级标题 1.创建分级标题时,避免跳过级别,如h3直接跳到h5,但允许从低级别跳到高级别. 2.不用 ...

  8. [转]Android SQLite

    数据库操作SQLite Expert Personal 3 注:下载相关SQLite的文档在:http://www.sqlite.org/ 具体的sql语句不作长细介绍,在本博客中也有相关的文章. 一 ...

  9. 第32讲:List的基本操作实战与基于模式匹配的List排序算法实现

    今天来学习一下list的基本操作及基于模式匹配的排序操作 让我们从代码出发 val bigData = List("hadoop","spark") val d ...

  10. codeforces966 A

    这题主要就是考虑y1两侧的最近的电梯和楼梯 当时主要是考虑  如果电梯在y1和y2中间的话   那么直接做电梯就是最优解   如果在y2右边就用abs去算 然后发现其实只考虑 y1的左右两边的电梯和楼 ...