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 %}
相关推荐
AntBlack3 分钟前
PyQtInspect : 推荐一个好用的 PythonQT 界面 Debug 工具
python·pyqt
flashlight_hi9 分钟前
LeetCode 分类刷题:1901. 寻找峰值 II
python·算法·leetcode
fwerfv34534529 分钟前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
蒋星熠1 小时前
反爬虫机制深度解析:从基础防御到高级对抗的完整技术实战
人工智能·pytorch·爬虫·python·深度学习·机器学习·计算机视觉
Predestination王瀞潞1 小时前
Python oct() 函数
开发语言·python
B站_计算机毕业设计之家2 小时前
python汽车数据分析可视化系统 爬虫 懂车帝 毕业设计 Django框架 vue框架 大数据✅
爬虫·python·数据分析·django·汽车·推荐算法·懂车帝
fl1768312 小时前
基于python+tkinter实现的自动组卷评卷考试系统python源码+课程设计+项目说明
开发语言·python·课程设计
王琦03182 小时前
Python 综合大作业
python
Dxy12393102162 小时前
Python自动连接已保存WiFi
开发语言·python
编程充电站pro2 小时前
面试陷阱:SQL 子查询 vs JOIN 的性能差异
数据库·sql