Задать вопрос
ZdraviiSmisl
@ZdraviiSmisl

Почему в `onkeydown` на документе записывается *null*?

По заданию нужно создать модальное окно с формой где есть текстовое поле и кнопки ок и cancel.

1)В строках (1), (2) и (3) мне не понятно почему в onkeydown на документе записывается null?

2)В задании в форме 3 элемента: поле для ввода и 2 кнопки почему фокус в решении автора при использования клавиш shift и tab переходит с последнего элемента на 1-ый и с 1-го на последний игнорируя промежуточный 2й элемент? Когда я нажимаю сочетание клавиш tab и shift или просто tab у меня последовательно фокус переходит по элементам. Флексы и Гриды тут не используются..

<html>

<head>
  <meta charset="utf-8">
  <style>
    html,
    body {
      margin: 0;
      padding: 0;
      width: 100%;
      height: 100%;
    }

    #prompt-form {
      display: inline-block;
      padding: 5px 5px 5px 70px;
      width: 200px;
      border: 1px solid black;
      background: white url(https://js.cx/clipart/prompt.png) no-repeat left 5px;
      vertical-align: middle;
    }

    #prompt-form-container {
      position: fixed;
      top: 0;
      left: 0;
      z-index: 9999;
      display: none;
      width: 100%;
      height: 100%;
      text-align: center;
    }

    #prompt-form-container:before {
      display: inline-block;
      height: 100%;
      content: '';
      vertical-align: middle;
    }

    #cover-div {
      position: fixed;
      top: 0;
      left: 0;
      z-index: 9000;
      width: 100%;
      height: 100%;
      background-color: gray;
      opacity: 0.3;
    }

    #prompt-form input[name="text"] {
      display: block;
      margin: 5px;
      width: 180px;
    }
  </style>
</head>

<body style="height:3000px">

  <h1>Нажмите на кнопку ниже</h1>

  <input type="button" value="Нажмите для показа формы ввода" id="show-button">


  <div id="prompt-form-container">
    <form id="prompt-form">
      <div id="prompt-message"></div>
      <input name="text" type="text">
      <input type="submit" value="Ок">
      <input type="button" name="cancel" value="Отмена">
    </form>
  </div>

  <script>
    // Показать полупрозрачный DIV, затеняющий всю страницу
    // (а форма будет не в нем, а рядом с ним, чтобы не полупрозрачная)
    function showCover() {
      var coverDiv = document.createElement('div');
      coverDiv.id = 'cover-div';
      document.body.appendChild(coverDiv);
    }

    function hideCover() {
      document.body.removeChild(document.getElementById('cover-div'));
    }

    function showPrompt(text, callback) {
      showCover();
      var form = document.getElementById('prompt-form');
      var container = document.getElementById('prompt-form-container');
      document.getElementById('prompt-message').innerHTML = text;
      form.elements.text.value = '';

      function complete(value) {
        hideCover();
        container.style.display = 'none';
        document.onkeydown = null; // (1)
        callback(value);
      }

      form.onsubmit = function() {
        var value = form.elements.text.value;
        if (value == '') return false; // игнорировать пустой submit

        complete(value);
        return false;
      };

      form.elements.cancel.onclick = function() {
        complete(null);
      };

      document.onkeydown = function(e) {
        if (e.keyCode == 27) { // escape
          complete(null);
        }
      };

      var lastElem = form.elements[form.elements.length - 1];
      var firstElem = form.elements[0];

      lastElem.onkeydown = function(e) {
        if (e.keyCode == 9 && !e.shiftKey) {
          firstElem.focus(); // (2)
          return false;
        }
      };

      firstElem.onkeydown = function(e) {
        if (e.keyCode == 9 && e.shiftKey) {
          lastElem.focus(); //(3)
          return false;
        }
      };


      container.style.display = 'block';
      form.elements.text.focus();
    }

    document.getElementById('show-button').onclick = function() {
      showPrompt("Введите что-нибудь<br>...умное :)", function(value) {
        alert("Вы ввели: " + value);
      });
    };
  </script>



</body>

</html>
  • Вопрос задан
  • 148 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
@acrades
1)В строках (1), (2) и (3) мне не понятно почему в onkeydown на документе записывается null?

Конкретно в строке (1) document.onkeydown присваивают null для того чтобы, браузер больше не обрабатывал данный код:
document.onkeydown = function (e) {
	if (e.keyCode == 27) { // escape
		complete(null);
	}
};

тем самым не давая вызвать функцию complete по нажатию на escape повторно.

игнорируя промежуточный 2й элемент

Второй элемент игнорируется из-за того что обрабатывать его нет нужды, так как фокус на нем будет в любом случае. Обработчик на первый элемент формы нужен для того чтобы по нажатию на shift + tab можно было перейти на последний элемент формы, а обработчик на последний элемент формы нужен для того чтобы по нажатию на tab можно было перейти на 1 элемент.
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

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