Django Model Choice Field - Depend On Other Field's Choice
Solution 1:
You probably can't because it depends of user interaction with your form: your server can't know in advance which element your user will select before sending the form to the browser. You could probably achieve this using ajax. I think a working process could be :
- Create a form with all the fields, and make
makefield hidden - Create a view (I'll call it
AjaxMakeFieldView) that will catch an ajax request taking avehicle_typeargument and return the HTML formake field, populated with relevant data. Add a URL in your URLConf for this view. - In your template, add a Javascript binding : when user select a
vehicle_type, the browser will send aan ajax request toAjaxMakeFieldViewand replace hiddenmakefield with returned HTML
If you don't want javascript, another way would be a two step form :
- A first form with a
vehicle_typefield - Once the first form is submitted, your user get a second form with a
makefield, which initial data is populated depending ofvehicle_typeselected in the first form.
I've never done this, but Django documentation on Form wizard seems a good place to start.
Solution 2:
This is how I ended up having two model choice fields depending on each other, on one page. In the below, field2 is depending on field1:
Javascript portion
Note that in $.each(), $.parseJSON(resp) should NOT be used (instead of just json) as we're already have it parsed by jQuery (due to the content_type='application/json' response) - see I keep getting "Uncaught SyntaxError: Unexpected token o".
$(document).ready(function() {
$("#id_field2").empty();
$("#id_field1").change(function(){
$.ajax({
url: "{% url 'ajax_get_field_2' %}",
type: 'GET',
data: {field1_id: $("#id_field1").val()},
dataType: "json",
success: function(resp){
$("#id_field2").empty();
$.each(resp, function(idx, obj) {
$('#id_field2').append($('<option></option>').attr('value', obj.pk).text(obj.fields.code + ' (' + obj.fields.affection + ')'));
});
},
error: function(jqXHR, textStatus, errorThrown) {
alert(errorThrown);
}
});
});
});
Django views.py portion
Note that this can probably be done by django-rest-framework as well.
I'm obtaining fields=('id', 'code', 'affection')) from my MyModel2 - these can then be reached in JQuery using obj.fielsd.<myfieldname>.
class AjaxField2View(generic.View):
def get(self, request, *args, **kwargs):
field_1 = get_object_or_404(MyModel1, pk=request.GET.get('field1_id', ''))
model2_results = MyModel2.objects.filter(k_value=field_1 .k_value)
return HttpResponse(serializers.serialize('json', model2_results, fields=('id', 'code', 'affection')), content_type='application/json')
Solution 3:
Another smart method query/free and no views needed,
is to make html tags for options that related to field A choice.
For example, in field B options:
<optionexample_tag="example_value"value="5"></option>This tag should be related to either field A value or text.
Using JS to display block/none using this option tag accordingly.
And don't forget to reset value for every time user changes field A.
Post a Comment for "Django Model Choice Field - Depend On Other Field's Choice"