自定义Django Form中choicefield下拉菜单选取数据库内容实例
作者:slamx 时间:2024-01-25 09:02:02
工作中遇到的问题,自定义了一个forms.form表单,某项需要作出下拉菜单,下拉菜单中的选项需要从数据库(objectForm models)中提取.
form.py为:
class objectForm(forms.Form):
pre = choicefield(lable = "工作")
最后的解决办法:
1.定义一个函数
def get_object(request):
r = [('', '----')]
for obj in objectModels.objects.all():
r = r + [(obj.id, obj.name)]
return r
2.在views.py的视图函数中加入
form.fields['pre'].choices = get_object(request)
收工!
百度了很多Django Form的问题都没有得到解决,写出来方便后来人。
补充知识:django form表单select下拉菜单数据源实时更新(每次访问获取一次数据库内容)
重点是: Form类对象实例化的时候,在类里边__init()__函数中加入重新更新select数据源
from django.shortcuts import render,redirect
from app3 import models
from app3 import form
from django import forms
from django.forms import widgets
#静态字段,value_list获取列表[()]加元组返回值
class Fromdb(forms.Form):
purpose = forms.CharField()
user = forms.IntegerField(
widget=widgets.Select()
)
#保证每次访问重新获取最新数据
def __init__(self,*args,**kwargs):
super(Fromdb,self).__init__(*args,**kwargs)
self.fields["user"].widget.choices=models.Stu.objects.values_list("id", "name")
def formdb(request):
stus = Fromdb()
return render(request,"formdb.html",{"stus":stus})
来源:https://blog.csdn.net/slamx/article/details/51095066
标签:Django,Form,choicefield,数据库
0
投稿
猜你喜欢
三谈Iframe自适应高度
2010-08-03 13:04:00
使用Python实现二分法查找的示例
2022-02-08 13:52:53
python mysql自增字段AUTO_INCREMENT值的修改方式
2023-10-15 07:12:19
SQL的substring_index()用法实例(MySQL字符串截取)
2024-01-27 19:30:19
实现div可编辑的常见方法
2007-11-06 12:02:00
Python中JSON的使用方法(超详细)
2023-11-15 23:04:19
Python高光谱遥感影像处理问题详细分析讲解
2023-10-04 04:03:37
使用Python批量压缩tif文件操作步骤
2021-03-27 00:04:10
解决django model修改添加字段报错的问题
2021-06-18 12:06:38
Python线性方程组求解运算示例
2021-07-26 16:52:29
Python实现的根据IP地址计算子网掩码位数功能示例
2021-08-30 21:21:31
Python学习之路之pycharm的第一个项目搭建过程
2022-01-14 23:16:52
IE里模拟DOMContentLoaded事件
2008-08-05 17:12:00
PHP chr()函数讲解
2023-06-05 04:03:58
Python利用matplotlib绘制约数个数统计图示例
2023-11-12 16:00:43
Python创建多线程的两种常用方法总结
2023-11-16 16:41:09
python统计cpu利用率的方法
2022-02-05 23:33:44
对网页切片算法问题的研究
2008-06-05 12:41:00
Python代码实现双链表
2021-12-26 15:55:04
Python爬虫工程师面试问题总结
2023-06-10 13:23:20