Для типичного запроса AJAX к серверу я связываю события ajaxStart и ajaxStop с открытием и закрытием модального диалогового окна jQueryUI. Тем не менее, у меня есть другой вариант использования, где есть 1 или более div (обычно 5 разделов), которые содержат довольно большие таблицы, отображающие строки данных, извлеченных из базы данных. Я заметил значительную задержку при переключении свойства отображения CSS в разделе (показано ниже).
<span id="SECTION_1_collapse">[+/-]</span><br />
<div id="SECTION_1">
<table>
<!-- Typically 100 cols x 250+ rows -->
</table>
</div>
<span id="SECTION_2_collapse">[+/-]</span><br />
<div id="SECTION_2">
<table>
<!-- Typically 100 cols x 250+ rows -->
</table>
</div>
...
...
...
Возможно ли это, или кто-нибудь когда-либо отображал модальное диалоговое окно jQueryUI при использовании метода .toggle ()? В этом случае элементы span с id = "SECTION_ _collapse" используются для свертывания элементов div с id = "SECTION_ ".
Спасибо заранее.
EDIT:
Да. Это возможно. Ответ был в обработчике .toggle (). Событие click все еще немного запаздывает, но в целом теряется меньше мертвого времени и, наконец, появляется некоторая обратная связь во время выполнения. Кэширование некоторых объектов jQuery также помогло.
Здесь приведен соответствующий раздел без всего кода сантехники, декларации диалогов и т. Д.
$('#SECTION_1_collapse').click(function(){
$('#wait_dialog').dialog("open");
$('#SECTION_1').toggle('slow', function(){
$('#wait_dialog').dialog("close");
});
});