Arhn - архитектура программирования

подавлять события клавиатуры для полей ввода

Я определил некоторую глобальную обработку клавиатуры, используя событие нажатия клавиши jQuery.

Есть ли способ подавить эти события для полей input/textarea, чтобы не мешать вводу текста?
Я использовал некоторые приемы с условиями, основанными на селекторах элементов. , но они оказали большое влияние на производительность, поскольку срабатывали при каждом нажатии клавиши.

(Некоторые из этих полей создаются динамически, что находится вне моего контроля — возможно, это имеет значение.)


  • [подключение этого к моему уже зарегистрированному аккаунту] 28.03.2009

Ответы:


1

Создайте обработчик onfocus для всех областей ввода и текста, который устанавливает некоторую глобальную переменную, указывающую, что события клавиатуры следует игнорировать. Создайте другой обработчик для события размытия, чтобы сбросить глобальную переменную.

var DISABLE_KEY_HANDLERS = false;

$('input[type=text], input[type=password], textarea').focus(function(){
  DISABLE_KEY_HANDLERS = true
})

$('input[type=text], input[type=password], textarea').blur(function(){
  DISABLE_KEY_HANDLERS = false
})

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

03.02.2009
  • Спасибо! Однако проблема заключается в динамически создаваемых элементах; Мне пришлось бы повторно запускать приведенный выше код всякий раз, когда создается новое поле ввода, что находится вне моего контроля. Тем не менее, это помогает, и, возможно, я смогу найти обходной путь для динамических частей... 03.02.2009
  • Вам следует изучить подключаемый модуль livequery: plugins.jquery.com/project/livequery. 03.02.2009
  • jQuery 1.3+ имеет встроенную функцию live(), вам также следует проверить это, если вы используете 1.3+ docs.jquery.com/Events/live 04.02.2009
  • live() еще не поддерживает фокус. 04.02.2009

  • 2

    Оказывается, мероприятие уже дает мне все, что мне нужно; ev.target — активный элемент DOM, поэтому я могу проверить, является ли это полем ввода.

    04.02.2009
    Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..