В jQuery UI виджете Dialog нет встроенной возможности показать окно с данными, полученными с помощью AJAX. Но это легко решаемо:
$('<div>').load('/some/url').dialog();
Или так, если после получения данных, их необходимо обработать:
$('<div id="my-dialog">Загрузка...</div>').dialog({
open: function() {
$.get('/some/url', function(response) {
$('#my-dialog').html('<p>' + response + '</p>');
});
},
close: function() {
$('#my-dialog').remove();
}
});
Похожие записи
- Вывести карту из конструктора Яндекс.Карт в jQuery UI Dialog
- Создаём зависимые списки с помощью jQuery и AJAX
- ScrollToFixed — jQuery плагин для фиксации блоков при пропадании их из зоны видимости
- Включаем поддержку HTML5 атрибута placeholder для устаревших браузеров
- Как скрыть элемент при клике вне этого элемента
Комментарии
Спасибо!
В коде есть небольшой баг.
Вместо:
$('#my-dialog').remove();
Надо:
$('#my-dialog').html('');
Иначе второй раз окно не выскочит.
выскочит
Если объявить блок #my-dialog в самом html заранее.
При объявлении диалогового окна установить параметр "autoOpen: false".
Окно открывать и закрывать через методы open и close.
То в этом случае remove() сносит весь блок #my-dialog и в дальнейшем диалоговое окно не открывалось по событию open.
Код из топика корректен, т.к. блок #my-dialog постоянно вновь создается.
Себе и другим на заметку.
Пример JQuery UI диалога с динамической загрузкой URL-адреса в IFRAME
Есть и Demo
@Игорь там больше интерес представляет автоматическое изменение высоты диалога под высоту фрейма. я пока выкручивался так:
не могу разобраться, как преобразовать код, чтобы был autoOpen: false?
Если просто добавляю перед open: function() , ничего не работает
В таком виде диалог открывается только раз. Помогите найти ошибку
как загрузить контент в Iframe + jquery dialog без перегрузки самой страницы
Iframe получается часть самой страницы src даёт перегрузку
Добавить комментарий