JQuery редактируемый select после вызова Ajax в Django
Я использую JQuery editable select в проекте Django, чтобы сделать виджеты select доступными для поиска.
Когда я вызываю другой шаблон, содержащий селекбоксы, с помощью Ajax, скрипт не будет применяться, если я не использую :
$.getScript("https://rawgit.com/indrimuska/jquery-editable-select/master/dist/jquery-editable-select.min.js").then(() => {}
Проблема в том, что это делает рендеринг Ajax очень медленным и случайным.
Есть ли способ кэшировать скрипт в родительском шаблоне и загрузить его только один раз, чтобы я мог повторно использовать его при рендеринге дочернего шаблона?
Вот мой вызов AJAX на родительском шаблоне :
$.ajaxSetup(
{
data: {select_update_record_project_id: sales_documents_id ,
csrfmiddlewaretoken: '{{ csrf_token }}'
},
});
$.ajax({
type: "GET",
url: "/my_url/",
cache: true, // I have tried both true and false
beforeSend: function(){
$('#div_master_sales_documents_edit').empty()
},
success: function (data) {
$.getScript("https://rawgit.com/indrimuska/jquery-editable-select/master/dist/jquery-editable-select.min.js").then(() => {
$("#div_master_sales_documents_edit").html(data);
});
}
});
}
Вот мой дочерний шаблон, отображенный после вызова Ajax :
<select id="sales_documents_editable_select_description_1"></select>
<select id="sales_documents_editable_select_description_2"></select>
<select id="sales_documents_editable_select_description_3"></select>
<script>
// this is where you apply the editable-select to select widgets
var list_selectbox_ids = ['sales_documents_editable_select_description_1','sales_documents_editable_select_description_2','sales_documents_editable_select_description_3'];
for (let i = 0; i < list_selectbox_ids.length; i++) {
$('#' + list_selectbox_ids[i]).editableSelect({effects: 'fade'}).on('select.editable-select', function (e, li) {
populate_sales_documents_selected_product($('#' + list_selectbox_ids[i]).attr('id'), li.text(), li.val())
});
}
</script>
Вы можете использовать класс вместо id.
<select class="eds" data-id="sales_documents_editable_select_description_1"></select>
<script>
function rednerSelect(){
$('.eds').each(function(){
$(this).editableSelect({effects: 'fade'})
.on('select.editable-select',
function (e, li) {
populate_sales_documents_selected_product(
$(this).attr('id'), li.text(), li.val())
});
});
}
</script>
вызывайте функцию при каждом вызове ajax
rednerSelect();