В элементе #ajax['event']
можно указывать не только дефолтные события такие как click
/change
/blur
, но и любые другие, которые будут вызваны через trigger()
Например есть форма с текстовым полем и нужно вызывать ajax обработчик в момент когда это поле теряет фокус, но только если значение поля было изменено. 'event' => 'blur'
не подходит, так как ajax будет вызываться даже если значение поля не изменилось.
Решение:
$form['mytextfield'] = array(
'#type' => 'textfield',
'#title' => 'My Textfield',
'#ajax' => array(
'callback' => 'mymodule_mytextfield_ajax_callback',
'event' => 'mytextfield_change', // имя пользовательского события
),
);
Javascript:
$('input[name="mytextfield"]').blur(function() {
if (this.defaultValue != this.value) {
$(this).trigger('mytextfield_change'); // вызываем событие
}
});
Написанное актуально для
Drupal 7
Похожие записи
- Показать второй шаг многошаговой формы в модальном окне
- Навесить на элемент managed_file свой ajax callback (Как обновить всю форму при загрузки файла в managed_file)
- Восстанавливаем позицию текстового курсора при ajax обновлении формы
- Как выполнять свой js-код до или после любых AJAX запросов (изменение работы AJAX API)
- AJAX в форме корзины Commerce 2
Комментарии
При срабатывании ajax-события (как в статье), срабатывает и функция валидации всей формы. Что по логике не нужно. Причем сначала происходит валидация, а потом ajax_callback, и все ошибки которая собрала незаполненная форма пишутся в указанный wrapper.
Я понимаю, что данная статья не об этом, но вызов все же обойти не смог.
https://api.drupal.org/api/drupal/developer!topics!forms_api_reference…
'#limit_validation_errors' => array()
Добавить комментарий