en.javascript.info/02-ui/05-widgets/05-custom-events/03-custom-select/solution.md
Ilya Kantor f301cb744d init
2014-10-26 22:10:13 +03:00

1.5 KiB
Raw Blame History

В этом решении для закрытия селекта по клику вне него используется отслеживание произвольных кликов вне документа.

Альтернатива -- события focusin/focusout, т.е. считаем, что пока фокус в селекте -- он открыт. С одной стороны, это более мощный способ, он позволяет перемещаться по элементам управления при помощи [key Tab] и корректно обрабатывать уход при помощи клавиатуры.

С другой стороны, это решение не универсально: если выводится alert, то фокус "прыгает" в него, уходя с элемента, а потом возвращается обратно. При этом JavaScript зарегистрирует уход фокуса focusout и возвращение focusin, хотя по смыслу фокус с элемента никуда не уходил, просто был alert.

Побочный эффект -- к закрытию и раскрытию (лишнему) элемента управления при таких "ненамеренных" потерях фокуса. Поэтому был выбран onclick.

Решение: [edit src="solution"]Открыть в песочнице[/edit]