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 %}
相关推荐
IT古董25 分钟前
第四章:大模型(LLM)】06.langchain原理-(3)LangChain Prompt 用法
java·人工智能·python
时序数据说3 小时前
时序数据库市场前景分析
大数据·数据库·物联网·开源·时序数据库
fantasy_arch5 小时前
pytorch例子计算两张图相似度
人工智能·pytorch·python
听雪楼主.7 小时前
Oracle Undo Tablespace 使用率暴涨案例分析
数据库·oracle·架构
我科绝伦(Huanhuan Zhou)7 小时前
KINGBASE集群日常维护管理命令总结
数据库·database
妖灵翎幺7 小时前
Java应届生求职八股(2)---Mysql篇
数据库·mysql
HMBBLOVEPDX7 小时前
MySQL的事务日志:
数据库·mysql
WBluuue7 小时前
数学建模:智能优化算法
python·机器学习·数学建模·爬山算法·启发式算法·聚类·模拟退火算法
赴3357 小时前
矿物分类案列 (一)六种方法对数据的填充
人工智能·python·机器学习·分类·数据挖掘·sklearn·矿物分类
大模型真好玩7 小时前
一文深度解析OpenAI近期发布系列大模型:意欲一统大模型江湖?
人工智能·python·mcp