python-web应用程序-Django-From组件

python-web应用程序-Django-From组件

添加用户时

原始方法(本质)【麻烦】

python 复制代码
def user_add(req):
	if req.method == 'GET':
        return render(req,'XXX.html')
    #POST请求处理:
    XXXXX
复制代码
-用户数据没有校验
-出现错误提示
-页面上的每一个字段都需要我们重新写一遍
-关联数据需要手动获取

Django组件

Form组件(方便)

view.py:

python 复制代码
class MyForm(Form):
    user = forms.CharField(widget = forms.Input)
    pwd = forms.CharField(widget = forms.Input)
    email = forms.CharField(widget = forms.Input)
    XXX=XXX
    ---
    
    
def user_add(req):
	if req.method == 'GET':
        form = MyForm()
        return render(req,'XXX.html',{'form':form})
    #POST请求处理:
    XXXXX
    

2.user_add.html

html 复制代码
<form method="post">
{{ form.user }}
{{ form.pwd }}
{{ form.email }}
<!-- 自动生成:<input type="text"placeholder="姓名" name="user"/> -->
或者:
{% for field in form %}
    {{field.lable}}  :  {{field}}
{% endfor %}    
</form>

ModelForm组件(更方便)

在modelForm中不需要手动写类的声明

view.py:

python 复制代码
class MyForm(ModelForm):
	xx = form.CharField(XXXX)  #新增加的字段
    class Meta:
    	model = model.类
    	fields = ['name','password','---']

其余与Form相同

  • 当传的对象为【对象,对象,对象,】时需要写该类的__str__方法

models.py

python 复制代码
class depart(models.Model):
	title = models.CharField(max_length=10)
	def __str__(self):
		return self.title
	#定制返回值

给自动生成的输入框增加样式

view.py中:

python 复制代码
class UserInfo(forms.ModelForm):
	class Meta:
        model = models.UserInfo
        fields = ['name','password','ahe']
        widgets = {
            'name':forms.TextInput(attrs={'class':'layui-input'})
            'password':forms.TextInput(attrs={'class':'BootStrip-form-control'})
            'XXXX':XXXX 
        }
python 复制代码
#自动添加样式
class UserInfo(forms.ModelForm):
	class Meta:
        model = models.UserInfo
        fields = ['name','password','ahe']
    def __init__(self,*args,**kwargs):
        super().__init__(*args,**kwargs)
        
       	for name,field in self.fields.items():
            if name =='':
                XXXXX#单独处理or  continue不处理
            field.widget.attrs= {'class':'XXXXX','placehoder':field.label}
            

校验

view.py:

python 复制代码
def user_add(req):
	if req.method == 'GET':
        form = UserInfo()
        return render(req,'XXX.html',{'form':form})
    #POST请求处理:
   	form = UserInfo(data = req.POST)
    if form.is_valid():
        print(form.cleaned_data)
    else:
        print(form.errors)
        #{'name':'yulin','password':'123456'...}
        #models.UserInfo.object.create(XXXX)
        form.save()
        return redirect('/user/list/')
    #检验失败
    return render(req,'user_add.html',{'form',form})
#该form中存在错误信息
html 复制代码
#前端获取错误信息
{%  for field in form  %}
<div class="form-group">
	<label>{{ field.Label }}</label>
			{{ field }}
<span styLe="coLor: red;">{{ field.errors.0 }}	</span>
</div>
{% endfor %}
相关推荐
思则变18 分钟前
[Pytest] [Part 2]增加 log功能
开发语言·python·pytest
漫谈网络1 小时前
WebSocket 在前后端的完整使用流程
javascript·python·websocket
AI、少年郎2 小时前
Oracle 进阶语法实战:从多维分析到数据清洗的深度应用(第四课)
数据库·oracle
赤橙红的黄2 小时前
自定义线程池-实现任务0丢失的处理策略
数据库·spring
try2find2 小时前
安装llama-cpp-python踩坑记
开发语言·python·llama
DataGear2 小时前
如何在DataGear 5.4.1 中快速制作SQL服务端分页的数据表格看板
javascript·数据库·sql·信息可视化·数据分析·echarts·数据可视化
weixin_438335402 小时前
分布式锁实现方式:基于Redis的分布式锁实现(Spring Boot + Redis)
数据库·redis·分布式
码不停蹄的玄黓3 小时前
MySQL Undo Log 深度解析:事务回滚与MVCC的核心功臣
数据库·mysql·undo log·回滚日志
Qdgr_3 小时前
价值实证:数字化转型标杆案例深度解析
大数据·数据库·人工智能
数据狐(DataFox)3 小时前
SQL参数化查询:防注入与计划缓存的双重优势
数据库·sql·缓存