You may want to execute some JavaScript when an inline form is added or removed
in the admin change form. The formset:added
and formset:removed
events
allow this. event.detail.formsetName
is the formset the row belongs to.
For the formset:added
event, event.target
is the newly added row.
In older versions, the event was a jQuery
event with $row
and
formsetName
parameters. It is now a JavaScript CustomEvent
with
parameters set in event.detail
.
在你的自定义 change_form.html
模板中,扩展 admin_change_form_document_ready
块并添加事件监听器代码:
{% extends 'admin/change_form.html' %}
{% load static %}
{% block admin_change_form_document_ready %}
{{ block.super }}
<script src="{% static 'app/formset_handlers.js' %}"></script>
{% endblock %}
document.addEventListener('formset:added', (event) => {
if (event.detail.formsetName == 'author_set') {
// Do something
}
});
document.addEventListener('formset:removed', (event) => {
// Row removed
});
有两点需要注意:
admin/change_form.html
,JavaScript 代码必须放在模板块中,否则它不会在最终的 HTML 中呈现。{{ block.super }}
是因为 Django 的 admin_change_form_document_ready
块中包含了 JavaScript 代码,用于处理更改表单中的各种操作,而我们也需要渲染这些代码。If your event listener still has to support older versions of Django you have to use jQuery to register your event listener. jQuery handles JavaScript events but the reverse isn't true.
You could check for the presence of event.detail.formsetName
and fall back
to the old listener signature as follows:
function handleFormsetAdded(row, formsetName) {
// Do something
}
$(document).on('formset:added', (event, $row, formsetName) => {
if (event.detail && event.detail.formsetName) {
// Django >= 4.1
handleFormsetAdded(event.target, event.detail.formsetName)
} else {
// Django < 4.1, use $row and formsetName
handleFormsetAdded($row.get(0), formsetName)
}
})
5月 12, 2023