Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
69 / 69 / 50
Регистрация: 25.03.2012
Сообщений: 241

Обработчики событий внутри метода

03.04.2014, 07:14. Показов 723. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
(function($){
  jQuery.fn.newMetod = function(){
 
 //какие то действия с объектом через this 
 
$(".drop-menu").click(function(){
$(this).css("display","none");
}); 
    return this; 
 }
    
 
})(jQuery);
Как грамотно поместить обработчик события внутри метода? А то получается вешаю метод на 3 объекта
JavaScript
1
2
3
$("#micro").newMetod();
$("#micro2").newMetod();
$("#micro3").newMetod();
обработчик $(".drop-menu").click вызывается 3 раза на 1 объекте, 2 при щелчке на втором, и 1 раз на 3.
Если поместить в ready в основной файл где пишется $("#micro").newMetod()... то все норм. Но нужно в файле со скриптом где метод.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.04.2014, 07:14
Ответы с готовыми решениями:

Метод append и привязанные обработчики событий
Здравствуйте, уважаемые форумчани. Есть проблема с методом append(). Начну с начала: Есть таблица товаров При клике на...

Объявление метода внутри объекта JAVASCRIPt
Как объявить метод внутри объекта JAVASCRIPT? Вот так написал, это правильно? <script> function snikers(){ var this.t =...

Обработчики событий в JS
Добрый вечер. Появился вопрос. Есть такой HTML код. <form action="#" method="post" class="search"> <input...

5
 Аватар для vovandr
636 / 523 / 195
Регистрация: 19.08.2013
Сообщений: 1,400
03.04.2014, 19:52
JavaScript
1
2
3
4
5
6
7
8
9
10
11
jQuery.fn.newMetod = function(){
     
       //какие то действия с объектом через this 
 
        $(this).on('click', '.drop-menu', function(){
            $(this).css("display","none");
        }); 
 
        return this; 
 
     }
0
69 / 69 / 50
Регистрация: 25.03.2012
Сообщений: 241
03.04.2014, 20:15  [ТС]
Уже сам немного разобрался в моем случае live() т.к. jq 1.3.2, элементы были динамически созданы поэтому с каждым созданным элементом в результате вызова метода на предыдущие вешались дополнительные обработчики. Теперь по 3 раза выполняется на любом объекте с классом .drop-menu.
JavaScript
1
2
3
$(".drop-menu").live('click', function(){
            $(this).css("display","none");
        });
В вашем варианте с on такого не происходит если несколько раз вызвать метод?
0
 Аватар для vovandr
636 / 523 / 195
Регистрация: 19.08.2013
Сообщений: 1,400
03.04.2014, 20:25
В вашем варианте с on такого не происходит если несколько раз вызвать метод?
Наверное надо взять и попробовать, как вы думаете?
0
69 / 69 / 50
Регистрация: 25.03.2012
Сообщений: 241
03.04.2014, 20:49  [ТС]
1.10.2 подключил
Делегированном виде ничего не происходит ошибок нет:
JavaScript
1
2
3
$(this).on('click', '.selecator', function(){
           $(this).next().slideToggle(100);
        });
В явном виде опять по 3 раза:
JavaScript
1
2
3
$('.selecator').on('click', function(){
           $(this).next().slideToggle(100);
        });
0
 Аватар для vovandr
636 / 523 / 195
Регистрация: 19.08.2013
Сообщений: 1,400
03.04.2014, 20:56
Я думаю у вас пробел в понимании контекста объектов. Приведите пример html с которым работаете, а еще лучше вместе с ним в песочницу залейте данный пример.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.04.2014, 20:56
Помогаю со студенческими работами здесь

Обработчики событий
Доброго времени суток! Друзья, помогите новичку разобраться. Вопрос такой: через циклы на страницу добавляются 2 набора кнопок. Не могу...

Class и обработчики событий
Доброго времени суток. Кто нибудь, когда нибудь, ложил обработчик события в класс, так делается вообще? В функции ложим, так-то...

JavaScript обработчики событий
Здравствуйте. У меня есть код на JavaScript, где при прохождении мышки над картинкой, меняется ее яркость. Но код работает только...

объясните про обработчики событий
подскажите, в чём разница между следующими инструкциями: element.addEventListener("click",...

Повесить обработчики событий на массив элементов
var headers=document.querySelectorAll("thead tr th"); for(var i=0;i<headers.length;i++) (function(){ ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru