首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >Django dynamic forms - on-the-fly field population?

Django dynamic forms - on-the-fly field population?
EN

Stack Overflow用户
提问于 2012-01-25 05:49:42
回答 2查看 25.2K关注 0票数 21

我整个下午都在浏览Django文档和谷歌搜索结果,但我仍然有点卡在创建动态表单的尝试中。我希望我只需要有人把我推向正确的方向:-)我刚刚开始学习Django,所以我仍然是一个非常初学者;然而,我已经是一个中级python用户了。

我要做的是创建一个动态表单,其中用户从下拉菜单中进行选择,然后根据该选择,表单的另一部分将自动更新,以显示与当前所选项目相关的结果,但显示的结果来自另一个数据库表。

我将尝试使用Django教程中的模型的简化版本来更好地说明我正在尝试做的事情:

代码语言:javascript
运行
AI代码解释
复制
# models.py
from django.db import models

class Poll(models.Model):
    question = models.CharField(max_length=200)

class Choice(models.Model):
    poll = models.ForeignKey(Poll)
    choice = models.CharField(max_length=200)

因此,假设我想要一个下拉选择字段,填充数据库中每个Poll的问题。我还想有一个文本字段,它显示了当前选择的投票对应的选择,这将更新在飞行中,每当用户选择一个不同的池。我已经能够通过放置一个按钮并将信息发送回表单来解决这一问题;但是,我正在尝试在用户做出选择时自动执行此操作。我的视图现在看起来像这样:

代码语言:javascript
运行
AI代码解释
复制
#view.py
from django import forms
from django.shortcuts import render_to_response

from myapp.models import Poll,Choice

class MyModelChoiceField(forms.ModelChoiceField):
    def label_from_instance(self, obj):
        return "%s" % obj.question

class PollSelectionForm(forms.Form):
    polls = MyModelChoiceField( queryset=Poll.objects.all() )

class ChoiceResults(forms.Form):
    def __init__(self, newid, *args, **kwargs):
        super(ChoiceResults, self).__init__(*args, **kwargs)

        self.fields['choice'] = forms.TextField( initial="" )

def main(request):
    return render_to_response("myapp/index.html", {
        "object": PollSelectionForm(), 
        "object2": ChoiceResults(),
    })

我的模板非常简单,就像这样

代码语言:javascript
运行
AI代码解释
复制
{{ object }}
{{ object2 }}

我确信我创建表单的方式可能也不是最好的,所以也请随意批评:-)正如我所提到的,我已经读到了涉及重新发布表单的解决方案,但我希望这能在运行中发生……如果我可以透明地转发,那么我想那就没问题了。我也看到过可以让你动态创建表单的库,但这似乎有点过头了。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-01-25 05:59:54

这里有一种方法-- Django/jQuery Cascading Select Boxes?

您可以创建一个仅将json呈现为字符串的新视图,然后在完成从第一个列表中进行选择时触发一个事件,该列表动态地从该json加载数据。

票数 6
EN

Stack Overflow用户

发布于 2012-01-25 09:45:26

我在这里做了类似的事情,根据下拉列表中的选择填充表单。也许这对你有帮助。

下面是用于预先填充表单的值的模型:

代码语言:javascript
运行
AI代码解释
复制
class OpmerkingenGebrek(models.Model):
    opmerking = models.CharField(max_length=255)
    advies = models.CharField(max_length=255)
    urgentiecodering = models.CharField(max_length=2, choices=URGENTIE_CHOICES_2011)
    bepaling = models.CharField(max_length=155,blank=True,null=True)
    aard = models.CharField(max_length=3, choices=AARD_CHOICES)

管理表单的视图:

代码语言:javascript
运行
AI代码解释
复制
def manage_component(request,project_id,.....):
    # get values for pre-populate
    og = OpmerkingenGebrek.objects.all()
    .........
    formset = ComponentForm(request.POST,request.FILES)
    .........
        )))
    return render_to_response(template, {
        'formset':formset,
        ........
        'og':og,
        },context_instance=RequestContext(request))

呈现表单的html

代码语言:javascript
运行
AI代码解释
复制
{% extends "base.html" %}
{% block extra_js %}
<script type="text/javascript" src="/media/js/limitText.js"></script>
<script type="text/javascript" src="/media/js/getValueOpmerking.js"></script>
{% endblock %}
<form enctype="multipart/form-data" method="post" action="">
{{ formset.as_table }}
</form>

<p>Choose default values:</p>
<select id="default" onChange="getValue(this)">
    {% for i in og %}
    <option value="{{ i.opmerking }} | {{ i.advies }} |  {{ i.urgentiecodering }} | 
    {{ i.aard }} | {{ i.bepaling }}">{{ i.opmerking }}</option>
    {% endfor %}
</select>

预先填充表单的javascript:

函数getValue(sel)

代码语言:javascript
运行
AI代码解释
复制
  {
    //get values
    var opm = sel.options[sel.selectedIndex].value;
    //split string to parts
    var parts = opm.split("|");
    // autofill form
    var opmerking = document.getElementById("id_opmerking");
    opmerking.value = parts[0];
    var aanbeveling = document.getElementById("id_aanbeveling");
    aanbeveling.value = parts[1];
    var opt = document.getElementById("id_urgentie");
    var urgentie = opt.selectedIndex;
    for(var i=0;i<opt.length;i++){
        if(opt.options[i].value == parts[2].split(' ').join('')){
            opt.selectedIndex = i;
       }};

    var opt = document.getElementById("id_aard");
    var aard = opt.selectedIndex;
    for(var i=0;i<opt.length;i++){
      if(opt.options[i].value == parts[3].split(' ').join('')){
          opt.selectedIndex = i;
          }};

    var bepaling = document.getElementById("id_bepaling");
    bepaling.value = parts[4];
  };
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8998428

复制
相关文章
python3-交互时隐藏输入的密码
# Auther: Aaron Fan #这个脚本请在命令行去执行才可以试出效果,pycharm这里无法测试这个脚本,切记! import getpass _username = "Aaron" _passwd = "abc,123" username = input("请输入你的用户名: ") #getpass这个模块可以帮助你输入密码时把密码隐藏 passwd = getpass.getpass("请输入你的密码: ") if username == _username and passwd == _passwd:    print("你的用户名密码输入正确。") else:    print("你的用户名或者密码错误!")
py3study
2020/01/08
1K0
在 Python 中隐藏和加密密码?
在当前的数字时代,安全至关重要。在我们作为开发人员的工作中,我们经常处理密码等机密数据。必须使用正确的密码加密和隐藏方法来保护这些敏感数据。Python 中许多可访问的技术和模块可以帮助我们实现这一目标。通过对可用实现的基本思想和示例的解释,本文研究了在 Python 中隐藏和加密密码的最佳技术和方法。
很酷的站长
2023/08/11
6440
在 Python 中隐藏和加密密码?
如何在 Python 中隐藏和加密密码?
有多种 Python 模块用于隐藏用户输入的密码,其中一个是**maskpass()模块。在 Python 中,借助maskpass()模块和base64()**模块,我们可以在输入时使用星号(*) 隐藏用户的密码,然后借助 base64() 模块可以对其进行加密。
海拥
2022/04/13
2.2K0
python如何保证输入键入数字
要求:用python写一个要求用户输入数字,如果不是数字就一直循环要求输入,直到输入数字为止的代码 错误打开方式: while True: ten=input('Enter a number:') if type(eval(ten))==type(int):    break 用这个输入字母可以可是输入字母就直接报错中断了 主要出在eval上。 第一个方案: while True: ten=input("x:") try: x=eval(ten)
marsggbo
2018/01/23
1.5K0
Android实现密码隐藏显示
需求:当用户点击提现按钮的时候,弹出输入支付密码的popupwindow,输入密码框后面有显示和隐藏支付密码的切换按钮。
程序员飞飞
2020/02/27
3.5K0
Android实现密码隐藏显示
Python隐藏特性:字符串驻留、常量折叠
>>> id(“some” + “_” + “string”) # 注意两个的id值是相同的.
小小科
2020/07/27
7060
网页标签闪烁 + 显示隐藏密码
感觉标签闪烁蛮有意思的,再加一篇凑一下字数。点击下方阅读原文,查阅文档,里面会有平时的积累。
OBKoro1
2020/10/27
2.6K0
网页标签闪烁 + 显示隐藏密码
Android 密码的隐藏和显示
在Android开发中,需要密码的隐藏和显示,下面就和大家分享一下使用方法: xml代码:
网罗开发
2021/01/29
2.2K0
Android 密码的隐藏和显示
长按键入
你的朋友正在使用键盘输入他的名字name。偶尔,在键入字符c时,按键可能会被长按,而字符可能被输入1次或多次。
WindRunnerMax
2020/10/26
9540
基于 Hexo 键入搜索功能
安装依赖。 前往博客根目录,打开cmd命令窗口执行npm install hexo-generator-search --save。
唐志远
2022/10/27
1.2K0
基于 Hexo 键入搜索功能
长按键入!
力扣题目链接:https://leetcode-cn.com/problems/long-pressed-name
代码随想录
2021/12/24
6.5K0
长按键入!
Python脚本命令行执行隐藏密码等敏感信息
Linux命令行登录系统,MySQL时,输入的密码看不到的,怎么在执行Python脚本时,密码等敏感信息也不让它出现呢?
酒馆丁老师
2020/09/08
1.8K0
Python脚本命令行执行隐藏密码等敏感信息
如何实现密码的显示和隐藏?
如图所示,我们在登录账号的时候经常会看到密码的显示和隐藏是可以进行切换的,那么到底怎么实现这个功能呢?
用户7656790
2020/12/14
6.2K0
如何实现密码的显示和隐藏?
c++输入隐藏密码的实现
最近在用C++编写一个图书管理系统, 其中需要用户的登录, 原来没有想太多, 就用了普通的cin输入, 但是前两天组里的同学说, 要是输入密码的时候能将其隐藏就好了。以前做网站的时候, 有各种标签属性可以很方便的实现这个功能, 但是现在是控制台…不知道怎么搞了。最后百度谷歌后发现了一个很神奇的函数
零式的天空
2022/03/08
1.9K0
EditText输入密码的显示和隐藏
密码的显示和隐藏是一个很常见的小知识点,主要包括2个部分:小图标的变化和EditText输入密码的显示和隐藏
AntDream
2019/07/15
2.6K0
C#实现登录界面,密码星号显示(隐藏输入密码)
在软件设计时,往往需要设置用户的登录权限。用户在填写密码时,如何实现输入隐藏,或者以“*”号进行隐藏显示?这里需要利用textBox的PasswordChar属性。
全栈程序员站长
2022/09/15
3.8K0
C#实现登录界面,密码星号显示(隐藏输入密码)
(四十二) 初遇python之帐号密码隐藏术
各位读者大大们大家好,今天学习python的帐号密码隐藏术,并记录学习过程欢迎大家一起交流分享。
XXXX-user
2019/07/23
1.8K0
(四十二) 初遇python之帐号密码隐藏术
Python根据字符分组数量判断密码安全强度
标准库itertools.groupby类用来根据指定的规则对序列中的元素进行分类,官方介绍如下:
Python小屋屋主
2019/12/13
1.7K0
Python根据字符分组数量判断密码安全强度
Python在import时遇到的惨案
    最近使用基于python语言的django框架开发web相关的应用,但是在访问页面的时候会不定时的报错,import导入报错
用户9127725
2022/08/08
4550
点击加载更多

相似问题

分布统计距离

10

计算元组上两个分布之间的统计距离

10

斑点密码中加法的微分扩散性质

10

安全距离计算

10

简单分组密码

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档