Javascript Django admin中的自定义相关下拉菜单
我有一个项目外键按阶段模型。我很难在Django管理页面中创建依赖下拉列表 我想在用户从该项目的(项目下拉)阶段选择项目时,在第二个dop dop down中显示该项目 实现这一目标的最佳方式是什么 如果下拉列表根据其父项的值筛选项目,那就太好了 1.在ModelAdmin中为Generaldata导入js媒体文件: 2.创建一个新的js文件,该文件保存了yourproject/yourapp/static/yourapp/目录或其他适当的目录。 3.创建处理ajax的视图 4.将“get_phases/添加到URL模式”。 请注意,您应该根据需要修改一些代码。Javascript Django admin中的自定义相关下拉菜单,javascript,django,ajax,django-admin,django-ajax-selects,Javascript,Django,Ajax,Django Admin,Django Ajax Selects,我有一个项目外键按阶段模型。我很难在Django管理页面中创建依赖下拉列表 我想在用户从该项目的(项目下拉)阶段选择项目时,在第二个dop dop down中显示该项目 实现这一目标的最佳方式是什么 如果下拉列表根据其父项的值筛选项目,那就太好了 1.在ModelAdmin中为Generaldata导入js媒体文件: 2.创建一个新的js文件,该文件保存了yourproject/yourapp/static/yourapp/目录或其他适当的目录。 3.创建处理ajax的视图 4.将“get_p
class Project(models.Model):
name = models.CharFieldmax_length = 100, unique= True)
short_name = models.CharField(max_length= 4, unique= True)
slug = models.SlugField(max_length= 100, allow_unicode=True, null=True, editable= False)
location = models.OneToOneField(Location, on_delete = models.SET_NULL, null= True, blank= False, verbose_name= 'موقعیت')
start_date = models.DateField(default= timezone.now, null= True, blank= True)
end_date = models.DateField(default= timezone.now, null= True, blank= True)
duration = models.IntegerField(default= 0, editable= False)
class Phase(models.Model):
title = models.CharField(max_length= 20)
class ProjectPhase(models.Model):
project = models.ForeignKey(Project, on_delete= models.CASCADE, related_name= 'phase')
phase = models.ForeignKey(Phase, on_delete=models.CASCADE, related_name= 'project')
start_date = models.DateField(default= timezone.now)
end_date = models.DateField(default= timezone.now)
duration = models.IntegerField(default= 0, editable= True)
class YourModelAdmin(admin.ModelAdmin):
form = YourModelForm
#list_display = ['your fields',]
class Media:
js = ("yourapp/selectajax.js",)
admin.site.register(YourModel, YourModelAdmin)
jQuery(function($){
$(document).ready(function(){
$("#id_project_select").change(function(){
// console.log(obj.currentTarget.value);
$.ajax({
url:"/get_phases/",
type:"POST",
data:{project: $(this).val(),},
success: function(result) {
console.log(result);
cols = document.getElementById("id_phase_select");
cols.options.length = 0;
for(var k in result){
cols.options.add(new Option(k, result[k]));
}
},
error: function(e){
console.error(JSON.stringify(e));
},
});
});
});
});
@login_required
def get_phases(request):
project = request.POST.get('project')
phases = {}
try:
if project:
prophases = Project.objects.get(pk=int(project)).phase
phases = {pp.phase.title:pp.pk for pp in prophases}
except:
pass
return JsonResponse(data=phases, safe=False)