---恢复内容开始---

一>
在数据库进行循环取多对多
def get_classlist(self):
l=[]
for cls in self.class_list.all():
l.append(str(cls))
return mark_safe(",".join(l))
<td>{{ customer.get_classlist }}</td>

二>

可以通过admin进入控制台进行录入数据库
1 from django.contrib import admin
2
3 # Register your models here.
4 from app01.models import *
5 admin.site.register(UserInfo)
6 admin.site.register(ClassList)
7 admin.site.register(Customer)
8 admin.site.register(Campuses)

在urls 引入

from django.contrib import admin

三>
进行数据录入 四>
更改auth,向其添加字段
from django.contrib.auth.models import AbstractUser
class UserInfo(AbstractUser):
tel=models.CharField(max_length=32,null=True,blank=True)
gender=models.IntegerField(choices=((1,"男"),(2,"女")),default=1)

五>别名
两个路径一个页面,通过reverse 判断
from django.urls import reverse

这里返回的是过略后的数据库
def customers(request):
if reverse("customers_list")==request.path: customers_list = Customer.objects.all()
else:
customers_list = Customer.objects.filter(consultant=request.user)

两个别名
path("customers/",views.customers,name="customers_list"),
path("mycustomers/",views.customers,name="mycustomers"),
六>关于过略
from django.db.models import Q
单个过略
val=request.GET,get("q")
filter=request.GRT.get("filter")
if val:
q=Q()
q.children.append((filter,val),) #y由于不可以将变量传到搜索的数据库,所以引用Q,通过q.children.append将两个变量赋值,后面可以继续
添加数据,默认且的关系
customers_list=customers_list.filter(q) djangoCrm2

1.模糊查询

由于Q的可以传递字符串属性,可以进行拼接__contains 进行搜索

2.未报名筛选,未报名的存储在models的 enroll_status_choices中,存储的是

enroll_status_choices = (('signed', "已报名"),
('unregistered', "未报名"),
('studying', '学习中'),
('paid_in_full', "学费已交齐")) 需要找到元祖对应的字段,在前段用get__signed__display显示 方法,找到select选择的属性,点击属性的时候讲原有的optiopn 替换成那4个状态,进行change的查询
$("#s1").change(function () {
if ($(this).val() === "status") {
let s1 = `
<select name="q" id="s2">
<option value="signed">已报名</option>
<option value="unregistered">未报名</option>
<option value="studying">学习中</option>
<option value="paid_in_full">学费已交齐</option>
</select>
`;
$(this).next().replaceWith(s1)
}
}) 未报名筛选

3.批量处理

进行批量处理时,需要将文件与checkbox 写入一个form表单,在循环的文件加入checkbox循环

运用获取批量处理的value 执行面向对象的反射

<td><input type="checkbox" name="select_pk_list" value="{{ customer.pk }}"></td>
def post(self,request):
#批量处理
print(request.POST)
func_str=request.POST.get("action")
data=request.POST.getlist("select_pk_list")
if not hasattr(self,func_str):
return HttpResponse("非法输入")
else:
func=getattr(self,func_str)
queryset=Customer.objects.filter(pk__in=data)
func(request,queryset)
return redirect(request.path)
def patch_delete(self,request,queryset):
queryset.update(sex="male") 批量处理

4.添加客户

通过forms.ModelForm 进行 MODELFORM操作,  引入form  定义form表单

class CustomerModelForm(forms.ModelForm):

class=MATE  fields=__all__""  model=Customer

通过传递form

form=CustomerModelForm(request.POst)

在页面上循环取出

成功返回添加页面

失败返回添加页面

5<>

编辑

唯一于添加不同的是

urls 通过re_path进行捕获到主键

edit_obj=request.POST.get(px=id)

form=CustomerModelForm(request.POst,instance=edit.obj)

来区分

这里若是要返回上一级,则需要额外她在在页面添加一个他要返回的上一级地址,

因为他只向的是edit1这个标准路由,要去到上一级需要拼接并且存储在返回的编辑标签上

然后利用redirect重定向 方法为

path=request.path

next="?next=%s",%spath

6>

公户转私户

用反射将

consultant=request.user
即可    7>
未报名颜色
def get_status(self):
status_color={
"studying":"green",
"signed":"#B03060",
"unregistered":"red",
"paid_in_full":"blue"
}
return mark_safe("<span style='color:white'>%s</span>"%(status_color[self.status],self.get_status_display()))

在前端传递的是对象,有自己的方法,,可以再models 生成一个方法,让这个方法被调用,返回值就是这个方法的结果


												

djangCrm的更多相关文章

随机推荐

  1. node版本切换工具n的使用介绍

    全局安装 npm install -g n mac的安装目录/usr/local/n/versions/node/13.2.0 因此首先在/usr/local/创建目录n,修改权限为普通访问权限,这样 ...

  2. 使用consul实现分布式服务注册和发现--redis篇

    安装consul client consul 客户端检脚本 ====================================================================== ...

  3. Oracle通过命令导入数据存储文件

    imp ztdev/ztdev FROMUSER=zt_base TOUSER=ztdev file=/home/oracle/zt_base_1023_sc_kk_new.dmp log=zt_ba ...

  4. Centos7挂载新硬盘

    1.查看系统是否检测到新的硬盘设备 ls /dev/ |grep sd linux 中所有外设都会在这个目录下,对应一个文件,其中第一块硬盘是sda,第二块硬盘是sdb,第三块硬盘是sdc.其中sda ...

  5. 可扩展标记语言XML之二:XML语言格式规范、文档组成

    大家好,小乐又来了,好久不见!这次接着上次可扩展标记语言XML之一:XML概念,作用,示例,继续讲述XML. 一.格式良好的 xml 1.语法规范: 1).必须有 XML 文档声明: <?xml ...

  6. FDD与TDD的区别

    LTE通常分为FDD LTE和TDD LTEFDD,频分双工(Frequency Division Duplexing)我和你通信,像广播一样,只能我说你听,是单工:像对讲机一样,同一时间只能一方说, ...

  7. ES(ElasticSearch)文档的表现形式以及增删改查

    1. ES中的文档 ES是面向文档(document oriented)的,这意味着它可以存储整个对象或文档(document).然而它不仅仅是存储,还会索引(index)每个文档的内容使之可以被搜索 ...

  8. SQL——IN操作符

    一.IN操作符基本用法 IN操作符用于在WHERE字句中规定多个值. 语法格式如下: SELECT 列名1,列名2... FROM 表名 WHERE 列名 IN(值1,值2...); 示例studen ...

  9. day37——阻塞、非阻塞、同步、异步

    day37 阻塞.非阻塞.同步.异步 进程运行的三个状态:运行.就绪.阻塞 执行的角度 阻塞:程序运行时,遇到了IO,程序挂起,CPU被切走 非阻塞:程序没有遇到IO,程序遇到IO但是我通过某种手段, ...

  10. Luogu3214 HNOI2011 卡农 组合、DP

    传送门 火题qwq 我们需要求的是满足元素个数为\(M\).元素取值范围为\([1,2^n-1]\).元素异或和为\(0\)的集合的数量. 首先我们可以计算元素有序的方案数(即计算满足这些条件的序列的 ...