Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.52/25: Рейтинг темы: голосов - 25, средняя оценка - 4.52
2 / 1 / 1
Регистрация: 24.10.2019
Сообщений: 18

Событие Click не работает с динамически генерируемыми элементами

13.03.2020, 18:38. Показов 4696. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
<!DOCTYPE html>
<html>
    <head>
        <title>canvasExample</title>
        <meta charset='utf-8' />
        <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
        <style type="text/css">
            .my-class{
                width: 150px;
                height: 150px;
                background: red;
            }
        </style>
 
    </head>
    <body>
        <div class="my-class"></div>
        <div id="some">
            
        </div>
        <br>
        <button id="bb">a sfas fgas d</button>
        <pre>После нажатия кнопки появляется второй блок точно такой же
как и первый но .on('click' на нём уже не работает</pre>
        <script type="text/javascript">
            $('.my-class').on('click',function(){
                alert(5);
            });
            $('#bb').click(function(){
                $('#some').html('<div class="my-class"></div>');
            });
        </script>
    </body>
</html>
Почему не работает онклик на второй блок который появляется после нажатия на кнопку
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.03.2020, 18:38
Ответы с готовыми решениями:

Событие Click не работает с динамически генерируемыми элементами
Вем привет. Хочу сделать выдвигающейся меню по кнопке, а в нутри его радио-кнопки. Таких блоков с выдвижным меню, я хочу создать несколько....

Создать событие Click для динамически создаваемого PictureBox
Хай всем! Не могу создать событие Click для динамически создаваемого PictureBox(для массива PictureBoxoв):wall:. Помогите плииз. Вот...

Не работает событие click()
Здравствуйте. Написал скрипт с использованием AJAX. Суть скрипта заключается в том, чтобы выводить входящие сообщения из БД. Скрипт...

3
Эксперт JS
 Аватар для DrType
6553 / 3624 / 1075
Регистрация: 07.09.2019
Сообщений: 5,877
Записей в блоге: 1
13.03.2020, 21:01

Не по теме:

Я плохо владею jQuery, но вот соображение на примере JS:


Если мы написали бы
JavaScript
1
for(let d of document.querySelectorAll('.my-class')){d.onclick=function(){alert(5)}}
то по клику на добавленные элементы функция не будет вызвана: коллекция элементов, на которые мы навесили обработчик, осталась прежней, она не изменилась с того момента, когда мы её ввели, и новые элементы в неё не входят.
Я думаю, здесь аналогичная ситуация.
2
Почетный модератор
12274 / 5340 / 268
Регистрация: 05.04.2011
Сообщений: 14,086
Записей в блоге: 2
14.03.2020, 10:40
Цитата Сообщение от Deventeex Посмотреть сообщение
Почему не работает онклик на второй блок который появляется после нажатия на кнопку
Потому что DOM поменялся после инициализации скрипта. Нужно в команде использовать find - то есть прежде, чем навесить на динамически появившийся элемент какое-то действие - его нужно заново найти.
1
Эксперт JS
6497 / 3908 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
15.03.2020, 19:35
Цитата Сообщение от Taatshi Посмотреть сообщение
его нужно заново найти.
В момент создания и навесить обработчик. Тогда и искать не надо.
JavaScript
1
2
3
4
5
6
            $('#bb').click(function(){
                $('#some').html('<div class="my-class"></div>');
                $('#some div').on('click',function(){
                alert(5);
            });
            });
Естественно, не всегда обязательно использовать анонимную функцию.
В большинстве случаев функции-обработчику красивее дать имя и вынести наружу из миллиона оберток.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.03.2020, 19:35
Помогаю со студенческими работами здесь

Не работает Click событие
Народ спасайте, делаю поиск как у гугл, суть такая через ajax запросы по слову которое вводит пользователь я смотрю в бд и вывожу ниже в...

Событие click не работает в firefox
В chrome работает в firefox нет. $(function() { $('#nav-icon').click(function() { $(this).toggleClass('open'); }); ...

Не работает событие click у кнопки пользовательского элемента управления
Сделал Я себе кнопку из пользовательского элемента управления, но когда я добавляю её на форму и добавляю событие click например что бы...

Не работает событие click для элементов полученных через аякс
Всем привет! Такая проблема - по нажатию на ссылку срабатывает скрипт. Выборку делаю по классу ссылки, и ловлю событие через...

Как обработать событие click и событие нажития стрелки?
Допустим есть кнопка влево-вправо для горизонтального листания товаров. Как нужно кроссбраузерно обрабатывать одновременно событие click...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru