2011-04-24 98 views
0

我想在django中生成動態表單。假設我有一個模型,其中包含由所有形式的字段組成的選擇。如果我的用戶選擇Textarea選項並給出標籤名稱,則表單將顯示帶有給定標籤的textarea。這可能是一個TextInput,單選按鈕等在Django中生成表格

所以我的模型看起來像:

TYPE_CHOICES = (
    (u'TextField',u'TextField'), 
    (u'TextArea',u'TextArea'), 
) 

class SocietyForm(models.Model): 
    title = models.CharField(max_length=255) 
    slug = models.SlugField() 
    form_info = models.ForeignKey(FormInfo) 


class FormInfo(models.Model): 
    label = models.CharField(max_length=255) 
    content_type = models.CharField(max_length=100,choices=TYPE_CHOICES) 
    form_info = models.ForeignKey(SocietyForm) 

到目前爲止好,但是當涉及到生成窗口小部件,以及我不知道這裏=) 我想,如果我根據選定的選項生成字典,那麼我可以將它分配給窗體的小部件。

'''                                                               
def select_form_type(instance):                                                        
    dict = {}                                                             
    if instance.content_type == "TextField":                                                     
     dict.update({'%s'instance.label:forms.TextInput()})                                                 
    else:                                                              
     dict.update({'%s'instance.label:forms.Textarea()})                                                 
    return dict                                                            
''' 

#class SocietyJoinForm(forms.ModelForm,instance): 

但是,SocietyJoinForm不能識別實例輸入。那麼有什麼想法?

回答

0

我只是碰巧遇到了所有較舊的問題。讓我知道你是否已經知道了這一點。

IMO,最簡單的方法是使用Javascript。除非你創建了自己的表單對象,否則你實際上無法在Django中改變它,在這種情況下,你很可能仍然需要使用Javascript。你可以這樣做:

<script type="text/javascript"> 
    function display_form_obj(){ 
     var type_selection = document.getElementById('id_content_type'); 
     var label = document.getElementById('id_label'); 
     var dyn_obj = document.getElementById('id_dyn_obj_div'); 
     if(type_selection.value and label.value){ 
      // Display the new object 
      if(type_selection.value == 'TextField'){ 
       dyn_obj.innerHTML = '<textarea ...>'; // Fill it with the info you need 
      } 
      else { 
       dyn_obj.innerHTML = '<input type="text" ...>'; // Fill with needed info 
      } 
     } 
     else { 
      dyn_obj.innerHTML = ''; 
     } 
    } 

    function set_form_obj_events(){ 
     var type_selection = document.getElementById('id_content_type'); 
     var label = document.getElementById('id_label'); 
     if(label.addEventListener){ 
      // Netscape, FF 
      type_selection.addEventListener('change', display_form_obj, false); 
      label.addEventListener('change', display_form_obj, false); 
     } 
     elif(label.attachEvent){ 
      // IE 
      type_selection.attachEvent('onchange', display_form_obj); 
      label.attachEvent('onchange', display_form_obj); 
     } 
    } 

</script> 
... 
<form ... onload="set_form_obj_events();"> 
    {{form.content_type}} 
    {{form.label}} 
    <div id="id_dyn_obj_div"></div> 
    ... 
</form> 

希望有所幫助。