Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: jquery Создание элемента в памяти, не помещая на страницу

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
ekkl
Отправлено: 16 Апреля, 2014 - 12:00:12
Post Id


Гость


Покинул форум
Сообщений всего: 69
Дата рег-ции: Окт. 2013  


Помог: 0 раз(а)




В общем, наверное, что-то упустил в документации.
Использую плавающий <div> для отображения некоторого контента в виде диалогового окна. Думаю это понятно. Решил не держать его на странице, а хранить в виде переменной в памяти. Не получается.
Если определить так
CODE (javascript):
скопировать код в буфер обмена
  1. var dialog = $('body').prepend('<dialog id="xform" class="small" data-reveal><div id="xform-content">\
  2. </div><a class="close-reveal-modal fi-x-circle"></a></dialog>');

То все работает и грузится нормально. Т.е. если поместил на страницу.
Но если сделать, допустим так
CODE (javascript):
скопировать код в буфер обмена
  1. var dialog = $($.parseHTML('<dialog id="xform" class="small" data-reveal><div id="xform-content">\
  2. </div><a class="close-reveal-modal fi-x-circle"></a></dialog>'));

Экран заливается цветом, как и при отображении окна, но оно не отображается. В консоли ошибка
CODE (htmlphp):
скопировать код в буфер обмена
  1. [11:57:19.019] TypeError: settings is undefined @ http://xandra.org/media/js/foundation.js:4112

Предполагаю, что библиотека не отслеживает этот элемент. Причина в этом, или в чём-то другом?
Стоит ли вообще копать, или поместить этот див на страницу и не парится?
 
 Top
IllusionMH
Отправлено: 16 Апреля, 2014 - 12:52:08
Post Id



Активный участник


Покинул форум
Сообщений всего: 4254
Дата рег-ции: Февр. 2011  
Откуда: .kh.ua


Помог: 242 раз(а)




ekkl, и как вы этот объект вставляете на страницу для отображения потом?
 
 Top
ekkl
Отправлено: 16 Апреля, 2014 - 12:54:22
Post Id


Гость


Покинул форум
Сообщений всего: 69
Дата рег-ции: Окт. 2013  


Помог: 0 раз(а)




CODE (javascript):
скопировать код в буфер обмена
  1. $('#xform-content').html(templates[md5(href)]);
  2.         dialog.foundation('reveal', 'open');
  3.         $(document).foundation({bindings: 'events'}); //запустить обработку событий контента
 
 Top
IllusionMH
Отправлено: 16 Апреля, 2014 - 13:12:06
Post Id



Активный участник


Покинул форум
Сообщений всего: 4254
Дата рег-ции: Февр. 2011  
Откуда: .kh.ua


Помог: 242 раз(а)




ekkl, вы уверены что эти строки добавляют этот элемент в DOM? Как он должен отображаться, если его нет в документе?

(Отредактировано автором: 16 Апреля, 2014 - 13:12:43)

 
 Top
SAD
Отправлено: 16 Апреля, 2014 - 13:15:24
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2508
Дата рег-ции: Май 2009  
Откуда: Днепропетровск, Украина


Помог: 75 раз(а)




нахохой так делать ?
CODE (javascript):
скопировать код в буфер обмена
  1.     var dialog = $($.parseHTML('<dialog id="xform" class="small" data-reveal><div id="xform-content">\
  2.    </div><a class="close-reveal-modal fi-x-circle"></a></dialog>'));


просто


CODE (javascript):
скопировать код в буфер обмена
  1.     var dialog = $('<dialog id="xform" class="small" data-reveal><div id="xform-content">\
  2.    </div><a class="close-reveal-modal fi-x-circle"></a></dialog>');
 
 Top
ekkl
Отправлено: 16 Апреля, 2014 - 13:20:06
Post Id


Гость


Покинул форум
Сообщений всего: 69
Дата рег-ции: Окт. 2013  


Помог: 0 раз(а)




Используется библиотека Zurb Foundation. Вторая строчка отображает диалоговое окно.
Я так понял, что для отображения нужно добавить єлемент в DOM. Отсюда я вижу два выхода: либо вернуться к первому варианту, либо править библиотеку Zurb, чтобы перед отображением добавлялся элемент.
Просто в примерах на сайте див уже был в документе статически.
Наверное, лучше вернуться к первому варианту, я так думаю...
 
 Top
IllusionMH
Отправлено: 16 Апреля, 2014 - 13:26:59
Post Id



Активный участник


Покинул форум
Сообщений всего: 4254
Дата рег-ции: Февр. 2011  
Откуда: .kh.ua


Помог: 242 раз(а)




ekkl, если этот скрипт выполняется всегда, то можно этот блок вообще в конец документа вставить и спрятать стилями.
 
 Top
ekkl
Отправлено: 16 Апреля, 2014 - 13:51:47
Post Id


Гость


Покинул форум
Сообщений всего: 69
Дата рег-ции: Окт. 2013  


Помог: 0 раз(а)




Он и так спрятан благодаря data-reveal
А в скрипте лучше сделать так?
CODE (javascript):
скопировать код в буфер обмена
  1. var daialog=$('#xform')

Как я понял.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« JavaScript & VBScript »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB