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 本 ...
随机推荐
- GDI基础(2):绘制文本
1.TextOut()和DrawText()函数 CDC::TextOut()在窗口的指定位置处输出文本,函数声明: virtual BOOL TextOut(int x, int y, LPCTST ...
- 第10章:MongoDB-CRUD操作--文档--修改--修改器
① $set:进行内容的重新设置 语法:{"$set" : {"成员" : "新内容"}}: 范例:将年龄是20岁的人的成绩修改为89 db ...
- 同时安装python2.7和python3.5
同时安装python2.7和python3.5,并配置sublime ctrl+B选择运行python版本 安装python 首先是安装两个版本的python,并配置相应的环境变量 1.在下载安装好P ...
- Java实现FTP批量大文件上传下载篇1
本文介绍了在Java中,如何使用Java现有的可用的库来编写FTP客户端代码,并开发成Applet控件,做成基于Web的批量.大文件的上传下载控件.文章在比较了一系列FTP客户库的基础上,就其中一个比 ...
- canvas打字效果
运用fillText,写的打字效果. 唯一麻烦的地方是,换行问题, 我是把字符串转化为数组,数组一个单位完成,就换行,继续下一个单位. <!doctype html> <html&g ...
- Docker mysql 主从
一.独立容器部署mysql主从 # 主从 my.cnf加上 [mysqld] server-id = XXX log-bin = mysql-bin log-bin-index = log-bin.i ...
- java实现在图片上编辑文本内容
package com.yin.text; import java.awt.Color; import java.awt.Font; import java.awt.Graphics2D; impor ...
- POJ3616--Milking Time(动态规划)
Bessie is such a hard-working cow. In fact, she is so focused on maximizing her productivity that sh ...
- java基础-day15
第01天 java面向对象 今日内容介绍 u 包和权限修饰符 u 内部类 第1章 包和权限修饰符 1.1 包的概述 java的包,其实就是我们电脑系统中的文件夹,包里存放的是类文件. 当 ...
- express 错误处理
原谅我的无知,之前学习express时,没想过需要错误处理.app.js也没认真看. 现在做具体的项目时,需要考虑到出错的情况. 其实有两种: 1.nodejs是单线程,如果挂掉了,网站就会崩溃,需要 ...