1.crm

  客户关系管理系统 :1.业务逻辑部分  2.权限插件

2.forms组件之modelform

  modelform就是model+form ,form根据model的字段生成标签 ,校验信息以及记录的功能 ,一步提交所有数据功能

  使用方法:

    1)定义个类继承forms.modelform

    2)定义哪些字段生成标签fields = '__all__'所有标签

    3)定义错误信息以字典的格式

    4)重写init方法使用插件给标签更新属性

    5)实例化modelform时候 ,如果是对已有对象进行修改需要添加 instance = 已有对象这个参数 ,指定修改对象生成前段标签

    6)is_valid()通过后可以直接使用 obj.save()提交数据

####model
class Dep(models.Model):
name = models.CharField(max_length=32, verbose_name='部门') #前端的显示label等于verbose_name
desc = models.CharField(max_length=128, verbose_name='描述') ####view
from django import forms # Create your views here.
class DepForm(forms.ModelForm):
# 也可以重写modle中已有的字段!
# name = forms.CharField()
class Meta:
model = models.Dep
fields = '__all__'
     #exclude = []      #排除字段
        error_messages = {            #给每个字段定义错误提示
'name':{
'required': '必填项'
},
'desc':{
'required': '必填项'
}
} def __init__(self, *args, **kwargs): #定义字段生成标签的属性!
super(DepForm, self).__init__(*args, **kwargs)
for field in self.fields.values():
field.widget.attrs.update({'class': 'form-control'}) def depadd(request):
form_obj = DepForm()
if request.method == 'POST':
form_obj = DepForm(request.POST)
if form_obj.is_valid():
form_obj.save()
return redirect(reverse('crm:deplist'))
print()
return render(request, 'depadd-edit.html', {'form_obj': form_obj})
def depedit(request, edit_id):
obj = models.Dep.objects.filter(pk=edit_id).first()
form_obj = DepForm(instance=obj)
if request.method == 'POST':
form_obj = DepForm(request.POST, instance=obj)
if form_obj.is_valid():
form_obj.save()
return redirect(reverse('crm:deplist'))
return render(request, 'depadd-edit.html', {'form_obj': form_obj})

3.优化删除功能使用alter弹窗提示

  异步思想: 删除点击后弹出框提示是否删除 ,如果删除前端移除该行记录 ,数据库中删除该条记录 (sweetalter + ajax + 前端js删除父级标签)

4.密码加密处理

  用户输入两次密码 ,如果成功 ,直接使用md5加密存放在数据库中 。所以用户输入的密码永远先做md5的处理   

  url部分

###url
from django.conf.urls import url, include
from django.contrib import admin
from crm.view import user, dep urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^user/list/', user.userlist, name='userlist'),
url(r'^user/add/', user.useradd, name='useradd'),
url(r'^user/edit/(\d+)/', user.useredit, name='useredit'),
url(r'^user/del/(\d+)/', user.userdel, name='userdel'), url(r'^dep/list/', dep.deplist, name='deplist'),
url(r'^dep/add/', dep.depadd, name='depadd'),
url(r'^dep/edit/(\d+)/', dep.depedit, name='depedit'),
url(r'^dep/del/(\d+)/', dep.depdel, name='depdel'), ]

  view部分

###dep-view
from django.shortcuts import render, reverse, redirect, HttpResponse
from crm import models
from django import forms # Create your views here.
class DepForm(forms.ModelForm):
# 也可以重写modle中已有的字段!
# name = forms.CharField()
class Meta:
model = models.Dep
fields = '__all__'
error_messages = {
'name': {
'required': '必填项'
},
'desc': {
'required': '必填项'
}
} def __init__(self, *args, **kwargs):
super(DepForm, self).__init__(*args, **kwargs)
for field in self.fields.values():
field.widget.attrs.update({'class': 'form-control'}) def deplist(request):
all_obj = models.Dep.objects.all()
return render(request, 'deplist.html', {'msg': all_obj}) def depedit(request, edit_id):
obj = models.Dep.objects.filter(pk=edit_id).first()
form_obj = DepForm(instance=obj)
if request.method == 'POST':
form_obj = DepForm(request.POST, instance=obj)
if form_obj.is_valid():
form_obj.save()
return redirect(reverse('crm:deplist'))
return render(request, 'depadd-edit.html', {'form_obj': form_obj}) def depadd(request):
form_obj = DepForm()
if request.method == 'POST':
form_obj = DepForm(request.POST)
if form_obj.is_valid():
form_obj.save()
return redirect(reverse('crm:deplist'))
return render(request, 'depadd-edit.html', {'form_obj': form_obj}) def depdel(request, del_id):
obj = models.Dep.objects.filter(pk=del_id).delete()
return redirect(reverse('crm:deplist')) ###user-view from django.shortcuts import render, reverse, redirect, HttpResponse
from crm import models
from django import forms
from django.forms import ValidationError
import hashlib class UserFrom(forms.ModelForm):
def __init__(self, *args, **kwargs):
super(UserFrom, self).__init__(*args, **kwargs) for field in iter(self.fields):
self.fields[field].widget.attrs.update({'class': 'form-control'}) re_password = forms.CharField(
label='确认密码',
widget=forms.PasswordInput()
) class Meta:
model = models.User
fields = ['name', 'age', 'sex', 'password', 're_password', 'dep', 'desc']
widgets = {
'password': forms.PasswordInput
} sex = forms.ChoiceField(
label='性别',
choices=((0, '男'), (1, '女')),
widget=forms.widgets.Select() ) def clean(self):
password = self.cleaned_data.get('password')
re_password = self.cleaned_data.get('re_password')
if password == re_password:
md5 = hashlib.md5()
md5.update(password.encode('utf-8'))
self.cleaned_data['password'] = md5.hexdigest()
return self.cleaned_data
self.add_error('re_password', '两次密码不同!')
raise ValidationError('两次密码不同!') def userlist(request):
all_obj = models.User.objects.all()
return render(request, 'userlist.html', {'msg': all_obj}) def useredit(request, edit_id):
obj = models.User.objects.filter(pk=edit_id).first()
form_obj = UserFrom(instance=obj)
if request.method == 'POST':
form_obj = UserFrom(request.POST, instance=obj)
if form_obj.is_valid():
form_obj.save()
return redirect(reverse('crm:userlist'))
return render(request, 'depadd-edit.html', {'form_obj': form_obj}) def useradd(request):
form_obj = UserFrom()
if request.method == 'POST':
form_obj = UserFrom(request.POST)
if form_obj.is_valid():
form_obj.save()
return redirect(reverse('crm:userlist'))
return render(request, 'depadd-edit.html', {'form_obj': form_obj}) def userdel(request, del_id):
models.User.objects.filter(pk=del_id).delete()
return redirect(reverse('crm:userlist'))

  html部分

###deplist.html

{% extends 'layout.html' %}
{% load static %}
{% block js %}
<script src="{% static '/js/sweetalter.js' %}"></script>
<script> $('.b1').click(function () { swal({
title: "提示",
text: "删除后无法恢复",
icon: "warning",
buttons: true,
dangerMode: true,
})
.then((willDelete) => {
let del_id = $(this).attr('del_id');
if (willDelete) {
$.ajax({
url: '/crm/dep/del/'+del_id,
type: 'get',
success: () => {
swal("已删除!", {
icon: 'success',
});
$(this).parent().parent().remove()
}
});
} else {
swal("取消删除!");
}
});
})
</script>
{% endblock %}
{% block content %}
<table class="text-center table table-striped table-bordered" style="margin-top: 20px">
<tr>
<td>序号</td>
<td>id</td>
<td>部门</td>
<td>描述</td>
<td>操作</td>
</tr>
{% for obj in msg %}
<tr>
<td>{{ forloop.counter }}</td>
<td>{{ obj.pk }}</td>
<td>{{ obj.name }}</td>
<td>{{ obj.desc }}</td>
<td><a href={% url 'crm:depedit' obj.pk %}><i class="fa fa-pencil-square-o" aria-hidden="true">&nbsp&nbsp&nbsp</i></a>
<a class="b1" del_id="{{ obj.pk }}" style="color: red"><i class=" fa fa-remove" aria-hidden="true"></i></a></td>
</tr>
{% endfor %}
</table>
{% endblock %} ###userlist.html
{% extends 'layout.html' %}
{% load static %}
{% block js %}
<script src="{% static '/js/sweetalter.js' %}"></script>
<script> $('.b1').click(function () { swal({
title: "提示",
text: "删除后无法恢复",
icon: "warning",
buttons: true,
dangerMode: true,
})
.then((willDelete) => {
let del_url = $(this).attr('del_url');
if (willDelete) {
$.ajax({
url: del_url,
type: 'get',
success: () => {
swal("已删除!", {
icon: 'success',
});
$(this).parent().parent().remove()
}
});
} else {
swal("取消删除!");
}
});
})
</script>
{% endblock %}
{% block content %}
<table class="text-center table table-striped table-bordered" style="margin-top: 20px">
<tr>
<td>序号</td>
<td>id</td>
<td>姓名</td>
<td>年龄</td>
{# <td>密码</td>#}
<td>部门</td>
<td>描述</td>
<td>操作</td>
</tr>
{% for obj in msg %}
<tr>
<td>{{ forloop.counter }}</td>
<td>{{ obj.pk }}</td>
<td>{{ obj.name }}</td>
<td>{{ obj.age }}</td>
<td>{{ obj.dep }}</td>
<td>{{ obj.desc }}</td>
{% if obj.age %}
<td><a href={% url 'crm:useredit' obj.pk %}><i class="fa fa-pencil-square-o" aria-hidden="true">&nbsp&nbsp&nbsp</i></a>
<a class="b1" del_url="{% url 'crm:userdel' obj.pk %}" style="color: red"><i
class=" fa fa-remove" aria-hidden="true"></i></a></td>
{% else %}
<td><a href={% url 'crm:depedit' obj.pk %}><i class="fa fa-pencil-square-o" aria-hidden="true">&nbsp&nbsp&nbsp</i></a>
<a class="b1" del_url="{% url 'crm:depdel' obj.pk %}" style="color: red"><i
class=" fa fa-remove" aria-hidden="true"></i></a>
</td>
{% endif %}
</tr>
{% endfor %}
</table>
{% endblock %} ###edit-add.html
{% extends 'layout.html' %}
{% block content %}
<div class="container col-lg-4 col-md-offset-3" style="margin-top: 30px;">
<form class="form-horizontal" method="post" novalidate>
{% csrf_token %}
{% for obj in form_obj %}
<div class="form-group {% if obj.errors %}has-error{% endif %}">
<label for="{{ obj.id_for_label }}"
class="col-sm-2 control-label">{{ obj.label }}</label>
<div class="col-sm-10">
{{ obj }}
<span class="help-block has-error">{{ obj.errors.0 }}</span>
</div>
</div>
{% endfor %}
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-default">保存</button>
</div>
</form>
</div>
{% endblock %}

最新文章

  1. 【Win10 应用开发】扫描和连接Wi-fi网络
  2. 通过代码实现gz压缩,并保持原来的文件名
  3. MyEclipse + Tomcat 热部署问题
  4. MongoDB 插入文档
  5. hdu 2999 Stone Game, Why are you always there? 博弈论
  6. objective-c 与 js之间传递中文乱码
  7. SPRING IN ACTION 第4版笔记-第九章Securing web applications-005-Applying LDAP-backed authentication
  8. 数学(欧拉函数):UVAOJ 11426 GCD - Extreme (II)
  9. FlowPlayer 参数说明
  10. stripslashes和addslashes的区别
  11. Android呼叫开发系列WebService
  12. [小北De编程手记] Lesson 01 - AutoFramework构建 之 从一个简单的Demo聊起
  13. iOS----------YYModel
  14. 关于4A网络安全管控平台控件加载失败的解决方法
  15. laravel orm进行增删改查
  16. 获取验证码的URL后边为什么要加上一个值不断变化的参数?
  17. 题解——Codeforces Round #508 (Div. 2) T3 (贪心)
  18. MySQL全文本搜索
  19. android 7.0拍照问题file:///storage/emulated/0/photo.jpeg exposed beyond app through ClipData.Item.getUri
  20. Android避免过度绘制之道

热门文章

  1. [C++]Game模板-正面视角
  2. maven私服的配置使用
  3. 【ZJOI 2014】力
  4. js 对 只包含简单类型数据的对象 为元素 组成的数组 进行去重
  5. SpringCloud(二):服务的注册与发现(Eureka)
  6. 单片机固件烧录器 Firmware Writer Android APP
  7. mssql sqlserver 如何编写case when 多条件呢?
  8. layui 动态设置 checbox 选中状态
  9. 【tf.keras】ssl.SSLError: [SSL: DECRYPTION_FAILED_OR_BAD_RECORD_MAC] decryption failed or bad record mac (_ssl.c:1977)
  10. MySQL的基础架构