Python之Django⾃动实现html代码(下拉框,数据选择)我就废话不多说了,还是直接看代码吧!
#模板
class IndexForm(forms.Form):
# 模板,⽤户提交的name和这⾥的变量名⼀定要是⼀致的.否则不能获取数据
user = forms.CharField(min_length=6, error_messages={'required': '⽤户名不能为空', 'min_length': '⽤户名长度不能⼩于6'})
email = forms.EmailField(error_messages={'required': '邮箱不能为空', 'invalid': '邮箱格式错误'})
"""
单选
favor = forms.ChoiceField(
choices=[(1, '⼩虎'), (2, '⼩⼩虎'), (3, '⼩B虎')]
)
"""
# 多选
favor = forms.MultipleChoiceField(
choices=[(1, '⼩虎'), (2, '⼩⼩虎'), (3, '⼩B虎')]
)
pass
#函数
def index(request):
obj = IndexForm()
return render(request, "index.html", {'obj': obj})
def edit_index(request):
obj = IndexForm({'user': 'root', 'email': '123@qq', 'favor': [2,3]})
return render(request, "index.html", {'obj': obj})
#前端
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<p>{{ obj.user }}</p>
<p>{{ ail }}</p>
<p>{{ obj.favor }}</p>
</body>
html下拉菜单的制作方法</html>
补充知识:django使⽤模板实现下拉菜单,菜单内容读取后台动态填充,并动态设置默认值
看代码吧!
<select id="heard1" class="form-control" required="" data-parsley-id="6485" name="name">
{% for name in data_list %}
<option id="name" value="{{ name }}" {% if name == role_name %} selected {% endif %}>{{ name }}</option>
{% endfor %}
</select>
这⾥⾯的重点是:
{% if name == role_name %} selected {% endif %} 这句话中得判断条件,name就是⾃⼰从data_list中遍历出来得那个name,
role_name也是⾃⼰传过来得数据,这个数据是我⾃⼰定义的另⼀个库中的数据,因为两个库是关联的;
data = (id=id)
role_name = data.user_role.name
query_name_list_set = RolesManage.objects.values("name")
data_list = []
for name_dict in query_name_list_set:
data_list.append(("name"))
return render(request, "users_manage/edit.html", {"data": data, "data_list": data_list, "role_name": rol
e_name})
贴上代码,为了防⽌⾃⼰忘记了好回过头来翻看
以上这篇Python之Django⾃动实现html代码(下拉框,数据选择)就是⼩编分享给⼤家的全部内容了,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论