0
我正在处理包含两种窗体的页面。其中一种形式是常规的名称,说明,注释等。第二种是两个下拉菜单 - Language
和Level
其中Level
与Language
使用AJAX
链接。如何在Django/AJAX中从窗体创建动态窗体集
我想让这种形式出现在页面上的次数与user
想要的次数一样多。因此,如果他们填写Language
和Level
,则会在旧的下方显示新的Language
和Level
表单。
问题是,如果表格是链接的,我必须分别标识每个Language
和Level
,所以我不能只复制form
这个重复。 (也许我可以,但我无法弄清楚,因为我是AJAX新手)。
这是一个create job
Django的/ HTML:
{% extends 'base.html' %}
{% load crispy_forms_tags %}
{% load static %}
{% block head %}
<script src="{% static "js/main.js" %}"></script>
{% endblock %}
{% block content %}
{% if user.is_authenticated %}
<form action="" method="post" enctype="multipart/form-data">{% csrf_token %}
{{ language_form }}
<button value="Update" type="submit">Submit</button>
</form>
{% endif %}
{% endblock %}
这是JQuery的:
$(document).on('change','#id_language',function(){
language_id = $(this).val();
request_url = '/get-highest-level/'+language_id+'/';
$.ajax({
url:request_url,
success: function(data){
var select = $('#id_level');
select.empty();
$.each(data, function (key,value) {
$('select[name="level"]').append('<option value="'+ key + '">'+value + '</option>');
});
return false;
}
})
});
和一个简单的观点:
@login_required
def create_order(request):
language_form = LanguageLevelForm(request.POST or None)
return render(request,'auth/jobs/create-job-test.html',context={'language_form':language_form})
我知道,它应该是可能的使用FormSet
但我不知道如何使它与JQuery
。
谢谢,我已经用单一的形式,并与表单集尝试了太多,但它不工作。可能是因为没有上课。我在我的问题 –
的底部添加了一个formset的html哦,这适用于链式表单,谢谢。但我仍然没有弄清楚如何在填充后添加它。第一个表格填写 - >第二个表格出现等 –