Запретить свечение фокуса управления формой Boostrap при нажатии

Я создал виртуальный каталог, в котором пользователи могут изменять имена файлов/каталогов.

Имена можно изменить только двойным щелчком мыши:

<input type = "text"
                   class = "form-control border-0 p-0 mb-1"
                   onblur = "this.readOnly='true';"
                   readonly = "true"
                   ondblclick = "handleDbClick(this)"
                   onkeydown = "handleEnter(event, this)"
                   value = "{{ dict.directory.current_name }}" />

но если я один раз нажму на поле ввода, вокруг ввода все равно будет свечение:

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

Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
0
50
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы можете добавить класс, который отключает стиль (тень поля, когда ввод сфокусирован):

  .nofocus:focus {
    box-shadow:none;
  }

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

Например, добавьте его в обработчик двойного щелчка.

  el.classList.remove('nofocus');

и удалите его при нажатии клавиши ввода в обработчике нажатия клавиш

  if (evt.keyCode === 13) el.classList.add('nofocus');

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

  if (!el.classList.contains('nofocus')) el.classList.add('nofocus');

демо:

.as-console-wrapper { max-height: 10% !important; bottom: 0; }
<!doctype html>
<html lang = "en">
  <head>
    <meta charset = "utf-8">
    <meta name = "viewport" content = "width=device-width, initial-scale=1">
    <link href = "https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel = "stylesheet">
   
    <title>Bootstrap Example</title>
    <script src = "https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js"></script>
    <style>
      .nofocus:focus {
        box-shadow:none;
      }           

    </style>
  </head>
  <body class = "p-3 m-0 border-0 bd-example m-0 border-0">

    

    <input type = "text"
    class = "form-control border-0 p-0 mb-1 nofocus"
    onblur = "handleBlur(this)"
    readonly = "true"
    ondblclick = "handleDbClick(this)"
    onkeydown = "handleEnter(event, this)"
    value = "{{ dict.directory.current_name }}" />



  <script>
    
    let isEditing = false;

    function handleBlur(el) {
      console.info('handleBlur');
      if (!isEditing) {        
        if (!el.classList.contains('nofocus')) {
          el.classList.add('nofocus');
          el.readOnly = 'true';
        }
      } else {
        el.focus();
      }


    }

    function handleEnter(evt, el) {
      if (!isEditing) return;
      console.info('handleEnter');
      el.removeAttribute('readonly');
      if (evt.keyCode === 13) {
          el.classList.add('nofocus');
          el.readOnly = 'true';
          isEditing = false;
      }
    }

    function handleDbClick(el) {
      isEditing = true;
      console.info('handleDbClick');
      el.classList.remove('nofocus');
    }
  </script>
      
 
  </body>
</html>

О, спасибо, это именно то, что я искал. Я думал, это какая-то приграничная собственность. Спасибо!

user3793935 20.08.2024 05:12

Другие вопросы по теме