自定义Django Form中choicefield下拉菜单选取数据库内容实例
工作中遇到的问题,自定义了一个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,redirectfrom app3 import modelsfrom app3 import formfrom django import formsfrom 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})
以上这篇自定义Django Form中choicefield下拉菜单选取数据库内容实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持好吧啦网。
相关文章:
1. 如何基于python3和Vue实现AES数据加密2. CSS Hack大全-教你如何区分出IE6-IE10、FireFox、Chrome、Opera3. CSS3实例分享之多重背景的实现(Multiple backgrounds)4. 解决VUE项目使用Element-ui 下拉组件的验证失效问题5. uni-app结合PHP实现单用户登陆demo及解析6. IntelliJ IDEA设置默认浏览器的方法7. 数组在java中的扩容的实例方法8. Vue+express+Socket实现聊天功能9. CSS3中Transition属性详解以及示例分享10. 解决VUE 在IE下出现ReferenceError: Promise未定义的问题

网公网安备