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

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

09.06.2016, 20:02. Показов 700. Ответов 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
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.06.2016, 20:02
Ответы с готовыми решениями:

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

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

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

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

Не по теме:

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  [ТС]
#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
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
10.06.2016, 14:09
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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.06.2016, 14:09
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs . . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru