Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
0 / 0 / 8
Регистрация: 29.07.2014
Сообщений: 514

JavaScript + обработка событий

02.03.2016, 11:21. Показов 779. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток может кто подскажет где я ошибся
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
<script type="text/javascript" src="http://code.jquery.com/jquery-1.12.0.min.js">
</script> <script type="text/javascript">
function SendGet()  {
  $.ajax({ type:'get',
            url:'close_nlc.php',
            data:{'nlc':1} })
            . done(function(){
             var button = document.getElementById ("button");
             button.removeEventListener("click",SendGet);
             button.addEventListener("click",SendGet_open);
            });}
 function SendGet_open()  {
  $.ajax({ type:'get',
            url:'open_nlc.php',
            data:{'nlc':1} })
            .done(function(){
             var button = document.getElementById ("button");
             button.removeEventListener("click",SendGet_open);
             button.addEventListener("click",SendGet);
            });}
 
</script>
<meta charset="utf-8">
<button id="button" onclick="SendGet()">Decrease</button>
при повторном нажатии не срабатывает function SendGet_open()
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.03.2016, 11:21
Ответы с готовыми решениями:

Обработка ajax событий
Здравствуйте. Есть айджакс запрос var ajaxrez = false; $('#button_save').click(function() { var text =...

Обработка событий click
Здравствуйте, есть поле для настольной игры, подскажите, как сделать обработку клика для определенной области на картинке, при нажатии...

Обработка событий без очереди
Скажите пожалуйста, сделал анимацию на несколько блоков, и образуется очередь, если быстро мышкой махать, отпустить, и получается очередь,...

4
 Аватар для Svid_off
82 / 82 / 38
Регистрация: 15.03.2013
Сообщений: 280
02.03.2016, 17:23
У меня на самом деле наблюдается другое поведение:
  1. при первом нажатии вызывается SendGet()
  2. при втором: SendGet() и SendGet_open()
  3. при третьем: SendGet() и SendGet()

то есть, все работает корректно, кроме того, что обработчик установленный через onclick не удаляется.
0
0 / 0 / 8
Регистрация: 29.07.2014
Сообщений: 514
03.03.2016, 06:25  [ТС]
а как исправить что бы при
первом нажатии сработало SendGet()
при втором SendGet_open()
при третьем SendGet()
при четвертом SendGet_open()
вообщем что бы они менялись
0
Hello Kitty
 Аватар для WhiteMind
690 / 562 / 402
Регистрация: 12.02.2016
Сообщений: 1,436
Записей в блоге: 1
03.03.2016, 07:03
JavaScript
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
$.fn.hook_se = function( fun ) {
    $(this).
        off("click.qwerasdf").
        on( "click.qwerasdf" , function() {
            fun();
        } );
}
 
function SendGet()  {
    $.ajax({ 
        type:'get',
    url:'close_nlc.php',
    data:{
            'nlc':1
        } 
    }).done(function(){
        $("#button").hook_se( SendGet_open );   
    });                     
}
 
function SendGet_open()  {
    $.ajax({ type:'get',
        url:'open_nlc.php',
        data:{
            'nlc':1
        } 
    }).done(function(){
        $("#button").hook_se( SendGet );
    });
}
 
$("#button").hook_se( SendGet );
1
0 / 0 / 8
Регистрация: 29.07.2014
Сообщений: 514
03.03.2016, 08:02  [ТС]
спасибо все работает можно еще вопрос
если у меня этих кнопок одинаковых будет ну скажим 100
PHP
1
<button id="button" onclick="SendGet()">Decrease</button>
PHP
1
<button id="button" onclick="SendGet()">Decrease</button>
PHP
1
<button id="button" onclick="SendGet()">Decrease</button>
.....
данная конструкция будет работать
по отдельности для каждой кнопки

Добавлено через 4 минуты
т.е. если вот так
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
35
36
37
38
39
<script type="text/javascript" src="http://code.jquery.com/jquery-1.12.0.min.js">
</script> <script type="text/javascript">
$.fn.hook_se = function( fun ) {
    $(this).
        off("click.qwerasdf").
        on( "click.qwerasdf" , function() {
            fun();
        } );
}
 
function SendGet(nlc)  {
    $.ajax({ 
        type:'get',
    url:'close_nlc.php',
    data:{
            'nlc':nlc
        } 
    }).done(function(){
        $("#button").hook_se( SendGet_open );   
    });                     
}
 
function SendGet_open(nlc)  {
    $.ajax({ type:'get',
        url:'open_nlc.php',
        data:{
            'nlc':nlc
        } 
    }).done(function(){
        $("#button").hook_se( SendGet );
    });
}
 
$("#button").hook_se( SendGet );
</script>
<meta charset="utf-8">
<button id="button" onclick="SendGet(1)">Decrease</button>
<button id="button" onclick="SendGet(2)">Decrease</button>
<button id="button" onclick="SendGet(3)">Decrease</button>
Добавлено через 2 минуты
она работает в одну сторону срабатывает только SendGet

Добавлено через 2 минуты
вот так вот работает но на сколько это правильно
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
35
36
37
38
39
<script type="text/javascript" src="http://code.jquery.com/jquery-1.12.0.min.js">
</script> <script type="text/javascript">
$.fn.hook_se = function( fun ) {
    $(this).
        off("click.qwerasdf").
        on( "click.qwerasdf" , function() {
            fun();
        } );
}
 
function SendGet(nlc)  {
    $.ajax({ 
        type:'get',
    url:'close_nlc.php',
    data:{
            'nlc':nlc
        } 
    }).done(function(){
        $("#button").hook_se( SendGet_open(nlc) );   
    });                     
}
 
function SendGet_open(nlc)  {
    $.ajax({ type:'get',
        url:'open_nlc.php',
        data:{
            'nlc':nlc
        } 
    }).done(function(){
        $("#button").hook_se( SendGet(nlc) );
    });
}
 
$("#button").hook_se( SendGet );
</script>
<meta charset="utf-8">
<button id="button" onclick="SendGet(1)">Decrease</button>
<button id="button" onclick="SendGet(2)">Decrease</button>
<button id="button" onclick="SendGet(3)">Decrease</button>
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.03.2016, 08:02
Помогаю со студенческими работами здесь

Метод .on() и делегированная обработка событий
Есть 3 div'а. В каждом div'е 1 таблица. Первый div с таблицей имеют данные при загрузке страница. Нажав на первую формируются данные...

Обработка событий получения и потери фокуса
код аписал такой: $(document).ready(function(){ $(&quot;#login&quot;).bind({ &quot;focus&quot;:function(){ ...

JavaScript + обработка событий
Доброго времени суток может кто подскажет где я ошибся &lt;script type=&quot;text/javascript&quot;...

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

Обработка событий IE
Как, создав окно IE из другого окна при помощи new ActiveXObject или CreateObject, назначить ему обработчики событий типа DocumentComplete...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты 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. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru