Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
3 / 3 / 2
Регистрация: 10.10.2010
Сообщений: 55

Callback animate jquery

01.07.2015, 22:28. Показов 1236. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет друзья! Вопрос такой - почему условие сработает если на момент скролла по клику эта переменная в true?
Пример тут - https://jsfiddle.net/34uas8ke/2/
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.07.2015, 22:28
Ответы с готовыми решениями:

Animate jQuery
Можно ли сдвинуть объект на столько пикселей, сколько будет в 3 раза больше его размера. Вряд ли понятно=) Короч объект 10px по Y, надо...

Подтормаживает jQuery.animate
Здравствуйте! Прошу помочь с проблемой... На сайте анимируется 3 объекта одновременно, один из них достаточно большой (внутри него...

JQuery анимация animate
Здравствуйте! Совсем недавно начал изучать JQuery, поэтому приходится задавать элементарные вопросы. Свой вопрос много раз гуглил и находил...

7
 Аватар для Sn1p3rOk
288 / 175 / 86
Регистрация: 19.04.2014
Сообщений: 1,095
01.07.2015, 22:46
Вы делаете клик, значение меняется на true, потом заканчивается анимация и значение меняется на false.

JavaScript
1
2
3
4
5
6
7
8
9
$('html, body').stop().animate({ 
        scrollTop: 1034
        },
        {
            duration: 300,
            complete: function() {
                noScrollAction = false; // ИЗ - ЗА ЭТОГО !!!
            }
        });
0
3 / 3 / 2
Регистрация: 10.10.2010
Сообщений: 55
01.07.2015, 22:59  [ТС]
Sn1p3rOk,
Переменная выставится в false после окончания анимации, т.е после окончания скроллинга..сообщение не должно выводится в момент скролла по кнопке. Потом я ставлю флаг скролла в неактивное положение - т.е дефолтное.

Добавлено через 1 минуту
Sn1p3rOk,
Представим, что по клику на кнопку, я таким образом блокирую вызов различных функций, которые дергаются при обычном скролле.
0
 Аватар для Sn1p3rOk
288 / 175 / 86
Регистрация: 19.04.2014
Сообщений: 1,095
01.07.2015, 23:10
По клику переменная true - вы правы, но как только заканчивается анимация, то она снова становится false... И сразу же выполняется код ниже, так как скролл произошел.
JavaScript
1
2
3
4
5
6
7
var noScrollAction = false; // не скроллим .... ???
 
$(window).scroll(function() {  
    if(!noScrollAction) {
            alert('никогда не покажусь при клике на кнопку!') // Ошибаетесь :) Условие уже false.
    }
});
0
3 / 3 / 2
Регистрация: 10.10.2010
Сообщений: 55
01.07.2015, 23:12  [ТС]
Попробую уточнить вопрос, почему каллбек вызывается раньше окончания функции анимации, тем самым выставляя переменную в false и мы попадаем в if в событии scroll.

Добавлено через 2 минуты
Sn1p3rOk,
Когда функция отработает, то скролл завершается и событие уже не может быть вызвано, ведь скролл закончен..разве не так?
0
 Аватар для Sn1p3rOk
288 / 175 / 86
Регистрация: 19.04.2014
Сообщений: 1,095
01.07.2015, 23:23
Цитата Сообщение от loms Посмотреть сообщение
Попробую уточнить вопрос, почему каллбек вызывается раньше окончания функции анимации, тем самым выставляя переменную в false и мы попадаем в if в событии scroll.
Я запустил Ваш код. Каллбек выполняется сразу же окончания анимации.
Цитата Сообщение от loms Посмотреть сообщение
Когда функция отработает, то скролл завершается и событие уже не может быть вызвано, ведь скролл закончен..разве не так?
Не совсем так. Ваша обработка события работает все время пока идет скролл. То есть Вы нажали на кнопку, пошел скролл, пошла обработка события, но условие в теле функции события не выполняется так как noScrollAction = true. Но как только анимация скролла завершается именно анимация, не сам скролл. Скролл завершается в доли миллисекунд после анимации, но в эти доли миллисекунд успевает сработать событие и в итоге проверка условия.
Как-то так...
1
3 / 3 / 2
Регистрация: 10.10.2010
Сообщений: 55
01.07.2015, 23:59  [ТС]
Sn1p3rOk,
Собственно это мне тоже приходило в голову, что анимация скролла и сам скролл имеют небольшие отклонения..хотя это и грустно, что же ничего не остается кроме как вручить setTimeout?

Добавлено через 29 минут
Грубый тест скорости выполнения - https://jsfiddle.net/34uas8ke/4/ разница от 1 до 20 мс в среднем
0
 Аватар для Sn1p3rOk
288 / 175 / 86
Регистрация: 19.04.2014
Сообщений: 1,095
02.07.2015, 00:20
Цитата Сообщение от loms Посмотреть сообщение
Собственно это мне тоже приходило в голову, что анимация скролла и сам скролл имеют небольшие отклонения..хотя это и грустно, что же ничего не остается кроме как вручить setTimeout?
Решил проблему таким способом.

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
33
34
35
36
37
var noScrollAction = false;
var temp = false;
 
$('#test').click(function(e)
{
    e.preventDefault();
    noScrollAction = true;
    
    $('html, body').stop().animate(
    { 
        scrollTop: 1034
    },
    {
        duration: 300,
        complete: function()
        {
            temp = true;
            noScrollAction = false;                   
        }
    });
});
 
 
$(window).scroll(function()
{
    if(!temp)
    {
        if(!noScrollAction)
        {
            console.log('никогда не покажусь при клике на кнопку!') 
        }
    }
    else 
    {
        temp = false;
    }
});
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.07.2015, 00:20
Помогаю со студенческими работами здесь

Управление анимациями Animate.css с помощью jQuery
Всем привет. Никак не могу разобраться с setInterval и setTimeout Суть такая, хочу сделать после полной загрузки сайта появление...

Callback работает не правильно jQuery
При создании слайдера столкнулся с тем что callback функция запущенная внутри функции animate() выполняется примерно на 400мс раньше...

This в callback функции jQuery.post
Нужно изменить поля объекта, который вызвал post запрос. Но в функции this указывает на что-то другое. Как обратиться к экземпляру объекта...

JQuery callback при изменении стиля, Реально ли?
Элементу присваивается стиль, напр. $('.element').css("color","white"); возможно ли сделать callback вызов функции по завершению...

Animate в Jquery
Добрый день. Нужна помощь с учебной задачей, Звучит примерно так: После щелчка по квадрату левая сторона квадрата движется к неподвижной...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs . . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru