Django模版语言自定义标签-实现前端 关联组合过滤查询
前端关联 组合过滤查询
实现效果如图:

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模版语言自定义标签-实现前端 关联组合过滤查询的更多相关文章
- Django模版语言的复用 1. include标签--模版导入 2.inclusion_tag自定义标签--模版导入 3.母版
include标签--模版导入 ''' 前提:项目中,往往会出现多个页面拥有一个或几个相同的页面版块,或是一个页面多个页面版块是相同的 如何运用:可以将多个样式标签的集合进行封装,对外提供版块的名字( ...
- Django模版语言 格式化显示 后台datatime()时间
Django模版语言 格式化显示 后台datatime()时间 场景描述:
- Django(模板语言-自定义filter和simple_tag)
Django(模板语言-自定义filter和simple_tag) filter过滤器的主要形式:变量|函数,意思是将变量交给函数处理,而自定义filter就是自己定义函数,因为用到已有的很少. ...
- Django 模版语言详解
一.简介 模版是纯文本文件.它可以产生任何基于文本的的格式(HTML,XML,CSV等等). 模版包括在使用时会被值替换掉的 变量,和控制模版逻辑的 标签. 例: {% extends "b ...
- Django模板语言,标签整理
Django模板语言 标签 内置标签引用 1. autoescape 控制自动转义是否可用. 这种标签带有任何 on 或 off 作为参数的话,他将决定转义块内效果. 该标签会以一个endautoes ...
- Django 模版语言
传入变量 {{ 变量名 }} 在 view.py 的函数返回 render 时在html文件名后传入一个字典,字典的 key 对应html文件中的变量名,value 为传入的值 views.py: d ...
- Jinja2模版语言自定义filter的使用
Jinja2模版语言,自带有一些filter,能够在前端的模版中控制数据按照相应的方式显示.比如以下两种filter,分别能在前端控制数字的近似精度显示和根据字符串长度补齐: round(value, ...
- django -- 模版语言之过滤器Filters和for循环
前戏 在前面写的图书管理系统中,我们对模版语言应该已经不陌生了,使用{{ }}包裹起来的就是模版语言,只需要记住两种就可以了 {{ 变量名 }} 变量相关的 {% %} ...
- 在django中使用自定义标签实现分页功能
效果演示: github地址:https://github.com/mncu/django_projects/tree/master/django_projects/pagination_test 本 ...
随机推荐
- 应用整合CAS服务器方法
概要 在开发WEB程序时需要整合CAS实现单点登录,下面介绍一下应用整合CAS服务器的过程. 在开始之前,我们确定CAS服务器已经搭建完毕. 实现步骤 1.新建一个maven项目,引入casclien ...
- Codeforces Round #546 (Div. 2) D 贪心 + 思维
https://codeforces.com/contest/1136/problem/D 贪心 + 思维 题意 你面前有一个队列,加上你有n个人(n<=3e5),有m(m<=个交换法则, ...
- 更新源pip
国内镜像源列表 豆瓣(douban) http://pypi.douban.com/simple/清华大学 https://pypi.tuna.tsinghua.edu.cn/simple/阿里云 h ...
- java socket之多人聊天室Demo
一.功能介绍 该功能实现了一个类似QQ的最简单多人聊天室,如下图所示. 二.目录结构 三.服务端 1)SocketServer类,该类是服务端的主类,主要负责创建聊天窗口,创建监听客户端的线程: pa ...
- C# 结构(struct)的特点
1.C# 中的结构有以下特点: 结构可带有方法.字段.索引.属性.运算符方法和事件. 结构可定义构造函数,但不能定义析构函数.但是,您不能为结构定义默认的构造函数.默认的构造函数是自动定义的,且不能被 ...
- HDU 5663 Hillan and the girl (莫比乌斯反演 + 分块)
题意:给定n,m,求,其中F(x)=0,,如果x是完全平方数,否则是1. 析: 由于按照题意的F,不好筛选,所以我们反过来,F(x),x是平方数,就是1,否则是0. 这个是可以预处理出来的,可以用筛选 ...
- BEM思想之彻底弄清BEM语法
BEM的意思就是块(block).元素(element).修饰符(modifier),是由Yandex团队提出的一种前端命名方法论.这种巧妙的命名方法让你的CSS类对其他开发者来说更加透明而且更有意义 ...
- AngularJS中$interval和$timeout的使用
我们在项目中会出现定时刷新,延迟加载等多种场景. 接下来就看$interval和$timeout的使用 $interval可用于定时任务,我们只需在controller注入$interval即可使用. ...
- HttpFilter
import java.io.IOException; import javax.servlet.Filter; import javax.servlet.FilterChain; import ja ...
- 笔记:IIFE 立即执行的函数表达式 +function ($) { }(window.jQuery);
在Bootstrap源码(具体请看<Bootstrap源码解析1>)和其他jQuery插件经常看到如下的写法: +function ($) { }(window.jQuery); 这种写法 ...