@lemonlimelike

Как вызывать модальное окно для нескольких кнопок?

Всем привет! Использую делегирование событий. И значит при клике на какой-то div'block нужно вызывать модальное окно. Таких div'block несколько, соответственно модальных окон тоже будет несколько. НО, можно ли сделать одно модальное окно и в него просто подставлять нужные данные? Типа, написать функцию, которая будет принимать пару параметров, и возвращать html код, который нужен для отображения модального окна. Такой подход будет правильным?
  • Вопрос задан
  • 179 просмотров
Решения вопроса 2
@choupa
Архитектор (обычный, который строит)
Да, такой подход будет правильным. А лучше изучите веб-компоненты.
Ответ написан
Комментировать
rockfeeler
@rockfeeler
Фронтендер, дизайнер, верстальщик-перфекционист
Да.
Например, сделать окно общего стиля, а внутрь напихать блоков с disaplay: none.
На div-trigger вешать атрибут типа data-pop="pop-01", "pop-02" и т.д., и давать блокам класс pop-01, pop-02...
Соответственно в скрипте писать примерно так:

$('[data-pop]').click(function() {
	var popName = $(this).attr('data-pop'); // или $(this).data('pop')

	$('.pop-' + popName).addClass('active') // что подразумевает в цсс-файле .data-pop.active {display: block}
});


Остальным блокам убирать класс active.
Это один из подходов. Может, вы прям из базы тягяете контент или аяксом, тогда все еще проще: подтягиваем контент и показываем поп-ап.
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 06:06
1500 руб./в час
22 нояб. 2024, в 06:04
1 руб./за проект
22 нояб. 2024, в 03:54
1500 руб./за проект