Addeventlistener scroll не работает

Содержание
  1. addEventListener (‘scroll’) для прокрутки
  2. 4 ответа
  3. Не работает window.scrollY
  4. 2 ответа 2
  5. Метод EventTarget.addEventListener()
  6. Синтаксис
  7. Параметры
  8. Возвращаемое значение
  9. Примечания по использованию
  10. Колбэк обработчика событий
  11. Безопасная проверка поддержки option
  12. Примеры
  13. Добавление простого обработчика
  14. HTML Содержимое
  15. JavaScript Содержимое
  16. Результат
  17. Слушатель события с анонимной функцией
  18. HTML Содержимое
  19. JavaScript Содержимое
  20. Результат
  21. Слушатель события со стрелочной функцией
  22. JavaScript
  23. Результат
  24. Примечания
  25. Зачем использовать addEventListener ?
  26. Добавление обработчика во время обработки события
  27. Несколько одинаковых обработчиков события
  28. Значение this в обработчике
  29. Наследство Internet Explorer и attachEvent
  30. Совместимость
  31. Старый способ регистрации обработчиков событий
  32. Вопросы памяти
  33. Улучшение производительности прокрутки с помощью passive: true
  34. Почему body.addEventListener(‘scroll’) не работает, а body.onscroll работает
  35. 1 ответ
  36. Похожие вопросы:

addEventListener (‘scroll’) для прокрутки

Это один из первых случаев, когда я на самом деле правильно использую React Hooks в проекте, так что терпите меня, если меня там нет.

В нижеприведенном компоненте моей целью является отображение при загрузке, и когда прокручиваемый div (не окно) прокручивается, я хочу скрыть его после того, как он прокручивает количество пикселей X.

Мой мыслительный процесс заключается в создании объекта useRef в элементе прокрутки

Я создал Codesandbox ниже, чтобы попытаться продемонстрировать, что я пытаюсь сделать. Как вы можете видеть в демонстрации, node.addEventListener(‘click’) работает нормально, однако когда я пытаюсь вызвать node.addEventListener(‘scroll’) , он не срабатывает.

Я не уверен, если я выбрал неправильный подход или нет, любая помощь будет принята с благодарностью. В демонстрации кодов и ящиков это изображение реакции, которое я пытаюсь скрыть при прокрутке, а не

4 ответа

Более простой подход для этого конкретного варианта использования может состоять в использовании onScroll реквизита и использовании свойства scrollTop из события target , чтобы выяснить, следует ли скрывать изображение или нет.

Читайте также:  От чего сломался датчик абс

Пример

В вашем примере прокрутка вызывается не на scrolling-element , а на scrolling-container , так что именно здесь вы хотите поместить свою ссылку: https://codesandbox.io/s/ko4vm93moo 🙂

Но, как сказал Тролль, вы также можете использовать реквизит onScroll!

В зависимости от вашего варианта использования, обычно также полезно throttle прокрутить прослушиватели событий, чтобы они не запускались при каждом изменении пикселя.

Функция throttle доступна в lodash.

Вот правильный способ привязать addEventListener к div с помощью useRef ()

Источник

Не работает window.scrollY

Всем привет. Проблемы две:

  1. Не работает addeventlistener scroll — вообще не срабатывает. Из-за этого пришлось сделать конструкцию ниже — она работает.
  2. Основная проблема — при попытке вызвать window.scrollY я всегда получаю 0.

Пробовал ставить общему блоку высоту auto, пробовал везде убирать height: 100% и в целом попробовал все доступные решения из интернета. Если нужна будет какая-то дополнительная информация, то я скину.

2 ответа 2

Описанная вами конструкция

точно рабочая. У нее широкая совместимость, согласно документации: Document: событие scroll. Ниже пример, демонстрирующий работу этого события.

Теперь к вопросу о том, почему вы всегда получаете 0. Это может происходить в том случае, если никакой документа прокрутки на самом деле не происходит. Например, в вашем примере в консоли всегда будет 0, так как при скроле не происходит смещения документа по вертикали. Смещения по вертикали не происходит, так как у документа не задана высота, больше чем отображаемая область и документ не содержит никакого контента, который мог бы его растянуть автоматически.

Пробовал ставить общему блоку высоту auto

Это наталкивает на мысль о том, что вам нужно считать количество пикселей, прокрученных от верха элемента, а не документа. Для этого есть свойство scrollTop .

Разницу между scrollY и scrollTop вы можете наблюдать в примере ниже. Обратите внимание, что во время прокрутки содержимого контейнера, scrollY не меняется, так как документ не смещается по вертикали.

Источник

Метод EventTarget.addEventListener()

Метод EventTarget.addEventListener() регистрирует определённый обработчик события, вызванного на EventTarget .

EventTarget может быть Element , Document , Window , или любым другим объектом, поддерживающим события (таким как XMLHttpRequest (en-US) ).

Синтаксис

Параметры

Прежде чем использовать определённое значение в объекте options , рекомендуется убедиться, что браузер пользователя поддерживает его, поскольку это дополнение, которое не все браузеры поддерживали исторически.

Возвращаемое значение

Примечания по использованию

Колбэк обработчика событий

Обработчик событий может быть задан либо как колбэк-функция, либо как объект реализующий EventListener , чей handleEvent() (en-US) метод служит как колбэк-функция.

Сама колбэк-функция имеет те же параметры и возвращаемое значение что и метод handleEvent() ; То есть колбэк принимает единственный параметр: объект основанный на Event описывая событие, которое произошло и ничего не возвращая.

Например, колбэк обработчика событий, который может использоваться для обработки fullscreenchange (en-US) и fullscreenerror (en-US) может выглядеть так:

Безопасная проверка поддержки option

В более старых версиях спецификации DOM третьим параметром addEventListener было логическое значение, указывающее, следует ли захватывать событие на этапе погружения. Со временем стало ясно, что необходимо больше вариантов. Вместо добавления дополнительных параметров в функцию (усложняя ситуацию при использовании необязательных значений) третий параметр был изменён на объект, который может содержать различные свойства, определяющие значения параметров для настройки обработчика событий.

Поскольку старые браузеры (а также некоторые не слишком старые браузеры) по-прежнему предполагают, что третий параметр является логическим, возникает необходимость создания своего кода, чтобы разумно обрабатывать этот сценарий. Вы можете сделать это, используя функцию обнаружения для каждого из интересующих вас параметров.

Например, если вы хотите проверить параметр passive :

Этот код создаёт объект options с геттером для свойства passive, устанавливающим флаг passiveSupported в true , если он вызван. Это означает, что если браузер проверяет значение свойства passive на объекте options , значение passiveSupported будет установлено в true; в противном случае он останется ложным. Затем мы вызываем addEventListener , чтобы настроить фальшивый обработчик событий, указав эти параметры для проверки опций, если браузер распознает объект в качестве третьего параметра.

Для проверки поддержки использования какой-либо опции можно просто добавить геттер для неё, используя код, подобный тому, что показан выше.

Если вы хотите добавить обработчик событий, использующий параметры, о которых идёт речь, вы можете сделать это подобным образом:

Здесь мы добавляем обработчик события mouseup (en-US) элемента someElement . Для третьего параметра, если passiveSupported имеет значение true , мы указываем объект options с passive: true ; в противном случае мы знаем, что нам нужно передать логическое значение, и мы передаём false как значение параметра useCapture .

Вы можете использовать стороннюю библиотеку, такую как Modernizr или Detect It, чтобы проверить поддержку необходимого свойства.

Примеры

Добавление простого обработчика

Эти примеры демонстрируют как использовать addEventListener() для наблюдения за щелчками мышкой по элементу.

HTML Содержимое

JavaScript Содержимое

В примере выше, modifyText() регистрирует обработчика для события click, используя addEventListener() . Клик в любом месте таблицы будет поднимать обработчик и запускать modifyText() .

Результат

Если вам нужно передать параметры в обработчик, вы можете использовать анонимные функции.

Слушатель события с анонимной функцией

HTML Содержимое

JavaScript Содержимое

Notice that the listener is an anonymous function that encapsulates code that is then, in turn, able to send parameters to the modifyText() function, which is responsible for actually responding to the event.

Результат

Слушатель события со стрелочной функцией

JavaScript

Результат

Обратите внимание: несмотря на то, что анонимные и стрелочные функции схожи, они имеют разные значения this .

Примечания

Зачем использовать addEventListener ?

addEventListener — это способ зарегистрировать обработчик события, описанный в документации W3C DOM. Вот список преимуществ его использования:

  • Позволяет добавлять множество обработчиков для одного события. Это особенно полезно для DHTML библиотек или Mozilla extensions, которые должны работать в условиях использования сторонних библиотек/расширений.
  • Предоставляет точный контроль фазы срабатывания(вызова) обработчика (захват или всплытие)
  • Срабатывает на любом DOM-элементе, а не только на HTML-элементах.

Добавление обработчика во время обработки события

Если EventListener добавлен к EventTarget во время обработки события, он не будет вызван текущими действиями, но может быть вызван на более поздней стадии обработки события, при восходящей обработке.

Несколько одинаковых обработчиков события

Если зарегистрировано несколько одинаковых EventListener на одном EventTarget с одинаковыми параметрами, дублирующиеся обработчики игнорируются. Так как одинаковые обработчики игнорируются, не требуется удалять их вручную с помощью метода removeEventListener.

Значение this в обработчике

Обычно желательно передавать элемент, на котором сработал обработчик события, например, при использовании обобщённых обработчиков для схожих элементов. При добавлении функции при помощи addEventListener() значение переменной this меняется — заметьте, что значение this передаётся в функцию от вызывающего объекта.

В примере выше значение переменной this внутри modifyText() при вызове событием клика равно таблице ‘t’. Это противоположно поведению, которое возникает, если обработчик добавлен в HTML-разметке:

Значение переменной this внутри modifyText() при вызове событием клика будет равно ссылке на глобальный (window) объект (или undefined при использовании strict mode)

Пример с использованием bind и без него:

Проблема в примере выше заключается в том, что вы не можете удалить обработчик, вызванный с bind . Другое решение использует специальную функцию handleEvent , чтобы перехватывать любые события:

Наследство Internet Explorer и attachEvent

В Internet Explorer младше 9 версии, вы можете использовать attachEvent вместо стандартного addEventListener . Для поддержки IE, пример выше может быть модифицирован следующим образом:

У attachEvent есть недостаток: this будет ссылаться на объект window , а не на элемент, на котором он был вызван.

Совместимость

Вы можете обойти методы addEventListener , removeEventListener , Event.preventDefault и Event.stopPropagation не поддерживаемы в IE 8 используя следующий код в начале вашего скрипта. Этот код поддерживает использование handleEvent и события DOMContentLoaded .

Note: useCapture не поддерживается, так как IE 8 не имеет альтернативного метода для этого. Также заметьте, что следующий код только добавляет поддержку IE 8. Также, он работает только при соблюдении стандартов: объявление DOCTYPE страницы обязательно.

Старый способ регистрации обработчиков событий

addEventListener() был добавлен в спецификации DOM 2 Events. До этого обработчики добавлялись следующим образом:

Этот метод заменяет текущие слушатели события click , если они есть. Тоже самое для других событий и ассоциируемых с ними обработчиков, таких как blur ( onblur ), keypress ( onkeypress ), и так далее.

Так как это по существу было частью DOM 0, этот метод имеет широкую поддержку и не требует специального кросс-браузерного кода; следовательно, это обычно используется, чтобы добавлять обработчики динамически, если не требуются расширенные возможности addEventListener() .

Вопросы памяти

В первом случае новая (анонимная) функция создаётся при каждом шаге цикла. Во втором случае одна заранее объявленная функция используется как обработчик события. Из этого следует меньшее потребление памяти. Более того, в первом случае, вследствие отсутствия ссылок на анонимные функции, невозможно вызвать element.removeEventListener, потому что нет ссылки на обработчик, в то время, как во втором случае возможно вызвать myElement.removeEventListener(«click», processEvent, false) .

Улучшение производительности прокрутки с помощью passive: true

Значение по умолчанию для параметра passive — false . Начиная с Chrome 56 (desktop, Chrome for Android, Android webview) значение по умолчанию для touchstart (en-US) и touchmove (en-US) равно true , а вызовы preventDefault() не разрешены. Чтобы отменить это поведение, необходимо установить параметр passive в false (см. пример ниже). Это изменение не позволяет обработчику блокировать показ страницы во время прокрутки пользователя. Демонстрация доступна на сайте разработчиков Google. Обратите внимание, что Edge вообще не поддерживает options , и добавление его без проверки поддержки помешает использовать аргумент useCapture .

Установка passive не имеет значения для основного события scroll (en-US) , поскольку его нельзя отменить, поэтому его обработчик в любом случае не может блокировать показ страницы.

Источник

Почему body.addEventListener(‘scroll’) не работает, а body.onscroll работает

Я только что столкнулся с интересным поведением:

При прокрутке тела обратный вызов в первом случае не срабатывает, а во втором работает нормально. Кто-нибудь знает причину этого?

Сначала я предположил, что событие производится на документе, однако тогда body.onscroll не должно быть вызвано.

1 ответ

Я делаю кое-что интересное JavaScript. У меня есть страница с разделами, и я отключаю окно scroll с jQuery, оно работает нормально. и я также пишу некоторые js, чтобы определить, хочет ли пользователь scroll, и я беру с параметром, прокручивается ли он вниз или вверх. если я scroll тела. Я пишу.

Не могли бы вы объяснить мне, почему scroll не работает? Он виден, но не работает, здесь вы можете просмотреть этот фрагмент кода. Что может быть недостающей частью? // GUI elements private JTextField textSend = new JTextField(20); private JTextArea textArea = new JTextArea(5, 20); private.

Вы могли бы сделать это по-другому:

Похожие вопросы:

мы пытаемся реализовать простое скрытие меню при прокрутке и отображение назад, когда пользователь прекращает прокрутку, но .on(‘scroll’) работает, а .off(‘scroll’) -нет.

Я хочу получить scroll даже и написать это: но когда я запускаю.

Я делаю кое-что интересное JavaScript. У меня есть страница с разделами, и я отключаю окно scroll с jQuery, оно работает нормально. и я также пишу некоторые js, чтобы определить, хочет ли.

Не могли бы вы объяснить мне, почему scroll не работает? Он виден, но не работает, здесь вы можете просмотреть этот фрагмент кода. Что может быть недостающей частью? // GUI elements private.

Я использую jQuery , чтобы проверить, прокручивается ли div . Он работает на window , но не работает на конкретном div. Работает отлично : $(window).scroll(function() < console.log('scroll.

В данный момент у меня есть небольшая проблема с адаптивным сайтом. Все страницы, кроме одной, не получают того импульса scroll, который вы обычно получаете от использования Интернета на вашем.

Я использую это, чтобы затухнуть div на scroll, но он не работает, 600-это смещение div. Я не могу понять, почему это не работает. $(window).scroll(function()< wScroll = $(this).scrollTop();.

Я пытаюсь реализовать большую функциональность загрузки в половине части страницы. Поэтому я поместил этот код внутрь ion-scroll, но почему-то текущая реализация не работает i.g. метод таков.

У меня есть панель навигации для прокрутки вниз до элементов привязки. Навбар находится внутри тела. Мой css : body < scroll-behavior: smooth; >На этой странице я также использую некоторые.

Источник

Оцените статью