Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 16.07.2018, 09:43
Аспирант
Отправить личное сообщение для VyacheslavBozere Посмотреть профиль Найти все сообщения от VyacheslavBozere
 
Регистрация: 18.03.2018
Сообщений: 31

Js onblur onfocus как спрятать элемент
Всех приветствую. Подскажите пож-та, пытаюсь сделать комбобокс и столкнулся с проблемой, нужно что бы onblur не срабатывал на дочерних элементах. А выбранное значение падало в input. Как это можно подправить ? Куда копать?

<!DOCTYPE HTML>
<html>

<head>
  <meta charset="utf-8">
  <script crossorigin src="https://unpkg.com/react@16/umd/react.production.min.js"></script>
    <script crossorigin src="https://unpkg.com/react-dom@16/umd/react-dom.production.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-standalone/6.25.0/babel.min.js"></script>
</head>

<body>

  <div  id="root">
    
  </div>
  <style>

  ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    width: 200px;
    background-color: #f1f1f1;
}

li a {
    display: block;
    color: #000;
    padding: 8px 16px;
    text-decoration: none;
}

/* Change the link color on hover */
 #target:hover {
    background-color: #555;
    color: white;
}
</style> 
  
  <script type="text/babel">
     
      let colors = ["green", "blue", "yellow"];
     let divSet = items => items.map(elem => <li> {elem} </li>);      

     class Combobox extends React.Component{
      constructor(props) {
      super(props);          
      this.closeHead = this.closeHead.bind(this);    
      this.onFocus = this.onFocus.bind(this);
      
    }

    onFocus() {
    container.hidden = false; 
     let getcolors = divSet(colors);     
      let res = <ul>{getcolors}</ul>;          
          ReactDOM.render(
           <div id="list">
           {res}           
           </div>,           
           document.getElementById('container')
         ); 
  }
     *!*
     closeHead() { 
        container.hidden = true;                        
        }  
*/*    
       
    render() {     

        return (
          <div >            
          <input type="text" id="text" placeholder="Начните вводить код или название"     onFocus={this.onFocus}  onBlur={this.closeHead}   />
          <div id="container"></div>
          </div>
       );
    }
  }

 ReactDOM.render(
    <Combobox  />,
    document.getElementById('root')
    )      
  
  </script>

</body>

</html>
Ответить с цитированием
  #2 (permalink)  
Старый 16.07.2018, 09:52
Аватар для j0hnik
Профессор
Отправить личное сообщение для j0hnik Посмотреть профиль Найти все сообщения от j0hnik
 
Регистрация: 01.12.2016
Сообщений: 3,650

в реакте не разбираюсь. нативно делают так
if(e.target == e.currentTarget) // если true то что-то делаем

e.currentTarget - Ссылка на объект слушателя события
e.target - Ссылка на объект, который отправил событие
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
нуб вопрос: как вызвать js и удалить элемент? genybr Элементы интерфейса 2 21.06.2016 13:14
Как изменить Select с помощью JS Alex921 Общие вопросы Javascript 4 04.01.2016 16:55
Как выбрать элемент, который отправлялся ajax Nifler jQuery 5 20.08.2015 08:42
как из js передать параметр в html wins Общие вопросы Javascript 6 22.12.2013 15:56
JS классы - как объединить функции в класс olga153b Events/DOM/Window 3 01.11.2011 14:13