Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
 
0 / 0 / 2
Регистрация: 15.08.2012
Сообщений: 102
1

Не закрывать результат поиска при нажатии на этот самый результат

09.06.2016, 20:02. Просмотров 365. Ответов 3


Добрый вечер, суть задачи такова: при нажатии на input становится видимым элемент #result, при нажатии в пределах элемента #box ничего не происходит, то есть элемент #result остается видимым, при нажатии вне элемента #box элемент #result скрывается, но у меня никак не получается сделать так, чтобы элемент #result оставался видимым при нажатии в пределах #box, помогите пожалуйста

Javascript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
(function($){
    $.fn.quicksearch=function(settings){
        var config={openSearch:function(){},changeSearch:function(){},badSearch:function(){},closeSearch:function(){},lang:'en'};
        if(settings)$.extend(config,settings);
        this.each(function(){
            function quickSearch(e){
                this.onkeyup=function(){
                    // проверка input
                }
                config.openSearch()
            }
            this.addEventListener('focus',quickSearch,false);
            document.getElementById('box').addEventListener('click', function(){
                return;
            }, false);
            this.addEventListener('blur',config.closeSearch,false);
        });
        return this
    }
})(jQuery);
$(function(){
    $('#qSearch').quicksearch({
        openSearch: function() {
            $('#result').show();
        },
        changeSearch: function(result) {
            // change search
        },
        badSearch: function(result) {
            // bad search
        },
        closeSearch: function() {
            $('#result').hide();
        }
    });
});
HTML5
1
2
3
4
<div id="box">
    <input type="text" id="qSearch" name="q">
    <div id="result" style="display:none;"></div>
</div>
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
09.06.2016, 20:02
Ответы с готовыми решениями:

Создание формы поиска на сайте. Почему не выводится результат поиска при вводе символов в поле поиска?
Добрый день! Создаю форму поиска с всплывающими подсказками. Попробую, выложить строки кода,...

Есть страница на html в ней проходим тест и узнаем результат.. Вопрос как этот результат записать в бд mysql в таблицу rezuitaty
вот код страницы: &lt;!DOCTYPE HTML PUBLIC &quot;-//W3C//DTD HTML 4.0 Transitional//EN&quot;&gt;...

Chrome перенаправление страницы поиска при клике на результат поиска
Странное поведение Chrome, кроме как записав видео, не нашел способа это лучше продемонстрировать. ...

Переписать данные из файла в новый файл, отбросив самый большой и самый маленький результат
Файл содержит данные о результатах 25 экспериментальных измерений. Переписать их в новый файл,...

3
Ренегат
Эксперт HTML/CSS
1735 / 1080 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
09.06.2016, 20:38 2

Не по теме:

MarkoPolo, у вас какая-то странная, совершенно нелепая помесь jQuery и нативного js


вопрос возникает вот с этой непонятно функцией
Javascript
1
2
3
            document.getElementById('box').addEventListener('click', function(){
                return;
            }, false);
Добавлено через 59 секунд
и ещё
при нажатии на box результаты должны появиться или наоборот исчезнуть?
0
0 / 0 / 2
Регистрация: 15.08.2012
Сообщений: 102
10.06.2016, 02:28  [ТС] 3
#box это родительский элемент для #input, #result и других элементов, которые будут находиться в нем, этот элемент имеет динамические размеры, когда #result скрытый, то #box имеет размеры только input-а, когда #result видим, то #box будет иметь размеры input и #result вместе взятых. То есть пользователь не может нажать на сам #box, а может только нажать на его дочерний элемент. Главными здесь являются input и #result. Нажимаешь на input - появляется #result, нажимаешь на #result, input или любой другой дочерний элемент #box - ничго не происходит, то есть #result никуда не исчезает и дальше остается видимым для пользователей, нажимаешь на любой другой элемент и #result скрывается.

Например имеем такой html:
HTML5
1
2
3
4
5
6
7
8
9
10
11
<body>
<h1>hello world</h1>
<div id="box">
    <input type="text" id="qSearch" name="q">
    <div id="result" style="display:none;"></div>
</div>
<span>1</span>
<span>2</span>
<span>3</span>
<h2>the end</h2>
</body>
Если мы нажимаем на дочерние элементы #box-а (#result, input), то #result остается видимым, если в данном случае нажимаем на span, h1, h2 или любой другой элемент для которого #box не является родительским , то #result скрывается

относительно
Цитата Сообщение от BANO Посмотреть сообщение
непонятно функцией
, то у меня тоже есть к ней вопросы, как раз вместо нее должна быть функция, которая будет оставлять видимым #result, когда пользователь будет клацать на элементы родителем которых является #box. И именно из-за этой функции я написал сюда на форум, чтобы более опытные программисты сказали, что должно быть вместо моей
Цитата Сообщение от BANO Посмотреть сообщение
непонятно функцией
0
Ренегат
Эксперт HTML/CSS
1735 / 1080 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
10.06.2016, 14:09 4
MarkoPolo, всё, я понял что вам нужно
правда я не знаю как это сейчас тут сделать именно в плагине, сейчас подумаю но есть способ

Javascript
1
2
3
4
document.addEventListener("click",function(event){
    if(event.target.id != "box" || event.target.parentNode.id != "box")
        config.closeSearch(event), event.preventDefault();
},true)
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
10.06.2016, 14:09

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

При нажатии на кнопку, не выводится результат вычисления
Ребятки, помогите пожалуйста разобраться с формой в Excel Visual Basic. На форму нужно вывести х и...

Скрипт не выводит результат при исполнении в терминале, построчно результат есть. Новичок в bash
Добрый день всем. Помогите разобраться. Я новичок в написании скриптов. Первая попытка, идея...

При нажатии клавиши enter не выводит результат в Tlistbox
В чем ошибка? При нажатии клавиши enter не выводит результат в Tlistbox... Может, что-то не...

При нажатии на ячейку, результат перенести на следующий лист
Нужно готовый результат перенести на следующий лист . Пример:C sheet1- при нажатии на Е4,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.