Penyesuaian JavaScript di admin¶
Peristiwa-peristiwa formulir berderet¶
Anda ingin mengerjakan beberapa JavaScript ketika sebuah formulir berderet ditambahkan atau dipindahkan di formulir rubah admin. Event jQuery formset:added dan formset:removed mengizinkan ini. penangan event melewatkan tiga argumen:
eventadalah peristiwa jQuery.$rowadalah baris baru ditambahkan (atau dipindahkan).formsetNameadalahformsetNamebaris milik.
Peristiwa dinyalakan menggunakan django.jQuery namespace.
Dalam cetakan change_form.html penyesuaian anda, perpanjang blok admin_change_form_document_ready dan tambah kode pendengar kejadian:
{% extends 'admin/change_form.html' %}
{% load static %}
{% block admin_change_form_document_ready %}
{{ block.super }}
<script src="{% static 'app/formset_handlers.js' %}"></script>
{% endblock %}
(function($) {
$(document).on('formset:added', function(event, $row, formsetName) {
if (formsetName == 'author_set') {
// Do something
}
});
$(document).on('formset:removed', function(event, $row, formsetName) {
// Row removed
});
})(django.jQuery);
Dua poin untuk diingat:
- Kode JavaScript harus berada di blok cetakan jika anda mewarisi
admin/change_form.htmlatau itu tidak akan dibangun dalam HTML akhir. {{ block.super }}ditambahkan karena blokadmin_change_form_document_readyDjango mengandung kode JavaScript untuk mengangani beragam tindakan dalam formulir rubah dan kami butuh itu dibangun juga.
Sometimes you'll need to work with jQuery plugins that are not registered
in the django.jQuery namespace. To do that, change how the code listens for
events. Instead of wrapping the listener in the django.jQuery namespace,
listen to the event triggered from there. For example:
{% extends 'admin/change_form.html' %}
{% load static %}
{% block admin_change_form_document_ready %}
{{ block.super }}
<script src="{% static 'app/unregistered_handlers.js' %}"></script>
{% endblock %}
django.jQuery(document).on('formset:added', function(event, $row, formsetName) {
// Row added
});
django.jQuery(document).on('formset:removed', function(event, $row, formsetName) {
// Row removed
});