admin管理员组文章数量:1351997
Binding a click event on the item list, the box keeps disappearing. Any idea why click event not working on item-list > div.
The idea is to fetch the text(from item-list) that is being clicked and put it in the input field ?
(function() {
$(".input-msg").focus(function() {
$(".item-list").css('display', 'block');
$(".item-list div").click(function() {
var inputValue = $('.input-msg');
var data = $(this).text();
inputValue.val(data);
});
}).blur(function() {
$(".item-list").css('display', 'none');
});
})();
.input-wrapper {
width: 300px;
}
.item-list {
display: none;
}
<script src=".1.1/jquery.min.js"></script>
<div class="input-wrapper">
<input type="text" class="input-msg" placeholder="click me">
<!-- input msg -->
<div class="item-list">
<div>This is item one</div>
<div>This is item one</div>
<div>This is item one</div>
<div>This is item one</div>
</div>
</div>
Binding a click event on the item list, the box keeps disappearing. Any idea why click event not working on item-list > div.
The idea is to fetch the text(from item-list) that is being clicked and put it in the input field ?
(function() {
$(".input-msg").focus(function() {
$(".item-list").css('display', 'block');
$(".item-list div").click(function() {
var inputValue = $('.input-msg');
var data = $(this).text();
inputValue.val(data);
});
}).blur(function() {
$(".item-list").css('display', 'none');
});
})();
.input-wrapper {
width: 300px;
}
.item-list {
display: none;
}
<script src="https://ajax.googleapis./ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="input-wrapper">
<input type="text" class="input-msg" placeholder="click me">
<!-- input msg -->
<div class="item-list">
<div>This is item one</div>
<div>This is item one</div>
<div>This is item one</div>
<div>This is item one</div>
</div>
</div>
Share
Improve this question
edited Jul 22, 2017 at 6:50
Death-is-the-real-truth
72.3k10 gold badges57 silver badges104 bronze badges
asked Jul 22, 2017 at 5:03
webmansawebmansa
851 gold badge1 silver badge12 bronze badges
4
- 1 your question is not clear? what you exactly want to achieve? and what problem you are facing? – Death-is-the-real-truth Commented Jul 22, 2017 at 5:04
- 1 please explain what you're trying to do, because from reading your code, i am still not sure what you're trying to do. – Raymond Seger Commented Jul 22, 2017 at 5:07
- Don't attach click listener in the focus handler, you end up to add a new listener every time the element gets the focus. – Teemu Commented Jul 22, 2017 at 5:11
- on click on the item list, its doen't insert the text, click function doesn't work ? also hide the item-list on body click – webmansa Commented Jul 22, 2017 at 5:18
4 Answers
Reset to default 4I think I got your Problem:-
1.remove blur
code. (because it's hiding div immediately when focus out from the input-box)
2.Put click
outside of focus
. (register listener only one-time which is enough)
3.Inside click
do the hide
code. (if you want to hide div after clicking on it's text div's)
Working snippet:-
(function() {
$(".input-msg").focus(function() {
$(".item-list").css('display', 'block');
});
$(".item-list div").click(function() {
var inputValue = $('.input-msg');
var data = $(this).text();
inputValue.val(data);
$('.item-list').hide();
});
})();
$(document).mouseup(function(e) {
if (!$(e.target).is('.item-list') && !$(e.target).is('.input-msg')) {
$('.item-list').hide(1000);
}
});
.input-wrapper {
width: 300px;
}
.item-list {
display: none;
}
<script src="https://ajax.googleapis./ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="input-wrapper">
<input type="text" class="input-msg" placeholder="click me">
<!-- input msg -->
<div class="item-list">
<div>This is item one</div>
<div>This is item Two</div>
<div>This is item Three</div>
<div>This is item Four</div>
</div>
</div><br>
Take a look at this.
(function() {
$(".item-list div").click(function() {
var inputValue = $('.input-msg');
var data = $(this).text();
inputValue.val(data);
$('.item-list').fadeOut('fast');
});
$(".input-msg").focus(function() {
$(".item-list").fadeIn('fast');
})
$(document).mouseup(function(e) {
if (!$(e.target).is('.item-list') && !$(e.target).is('.input-msg')) {
$('.item-list').fadeOut('fast');
}
});
})();
.input-wrapper {
width: 300px;
}
.item-list {
display: none;
}
<script src="https://ajax.googleapis./ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="input-wrapper">
<input type="text" class="input-msg" placeholder="click me">
<!-- input msg -->
<div class="item-list">
<div>This is item one</div>
<div>This is item two</div>
<div>This is item three</div>
<div>This is item four</div>
</div>
</div>
The item list disappears, because on a blur
event triggered by the input box, the list is cleared. I've mented out the code that is hiding the list, and moved it down to happen on the item list click
.
I've also moved the list click
handler from inside your blur
handler. This will prevent the click handler from being mounted again and again.
(function() {
$(".input-msg").focus(function() {
$(".item-list").css('display', 'block');
}).blur(function() {
// THIS IS YOUR ISSUE.
// We're going to move this line down to the
// `item-list` click handler.
// $(".item-list").css('display', 'none');
});
// You want to register this listener once,
// not every time user focuses on input box.
$(".item-list div").click(function() {
var inputValue = $('.input-msg');
var data = $(this).text();
inputValue.val(data);
});
$('.main-wrapper').children().not('.input-wrapper').click(function(){
// Hide the item list on body click.
// This was moved here from the `blur` handler above.
$(".item-list").css('display', 'none');
});
})();
.main-wrapper {
float: left;
width: 600px;
}
.other-wrapper {
float: left;
width: 300px;
}
.input-wrapper {
float: left;
width: 300px;
}
.item-list {
display: none;
}
<script src="https://ajax.googleapis./ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="main-wrapper">
<div class="input-wrapper">
<input type="text" class="input-msg" placeholder="click me">
<!-- input msg -->
<div class="item-list">
<div>This is item one</div>
<div>This is item one</div>
<div>This is item one</div>
<div>This is item one</div>
</div>
</div>
<div class="other-wrapper">Other stuff.</div>
<div>
const input = $("input")
const itemList = $(".item-list")
const items = $(".item-list > div")
const overlay = $(".overlay")
addClickTo(input, () => display(itemList, overlay))
addClickTo(items, (e) => {
const itemText = e.currentTarget.textContent
setValueOf(input, itemText)
dontDisplay(itemList, overlay)
})
addClickTo(overlay, () => dontDisplay(itemList, overlay))
// helpers
function dontDisplay(...elements) { elements.forEach((element) => element.style.display = "none") }
function display(...elements) { elements.forEach((element) => element.style.display = "block") }
function $(selector) {
const matchedElements = document.querySelectorAll(selector)
return matchedElements && matchedElements.length > 1
? matchedElements
: matchedElements[0]
}
function addClickTo(elements, handler) {
elements.forEach || (elements = [elements])
elements.forEach((element) => element.addEventListener("click", handler))
}
function setValueOf(input, text) {
input.value = text
}
const input = $("input")
const itemList = $(".item-list")
const items = $(".item-list > div")
const overlay = $(".overlay")
addClickTo(input, () => display(itemList, overlay))
addClickTo(items, (e) => {
const itemText = e.currentTarget.textContent
setValueOf(input, itemText)
dontDisplay(itemList, overlay)
})
addClickTo(overlay, () => dontDisplay(itemList, overlay))
// helpers
function dontDisplay(...elements) { elements.forEach((element) => element.style.display = "none") }
function display(...elements) { elements.forEach((element) => element.style.display = "block") }
function $(selector) {
const matchedElements = document.querySelectorAll(selector)
return matchedElements && matchedElements.length > 1
? matchedElements
: matchedElements[0]
}
function addClickTo(elements, handler) {
elements.forEach || (elements = [elements])
elements.forEach((element) => element.addEventListener("click", handler))
}
function setValueOf(input, text) {
input.value = text
}
.item-list {
display: none;
position: relative;
cursor: pointer;
}
input {
position: relative;
}
.overlay {
display: none;
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
<div class="input-wrapper">
<div class="overlay"></div>
<input type="text" class="input-msg" placeholder="click me">
<!-- input msg -->
<div class="item-list">
<div>This is item one</div>
<div>This is item two</div>
<div>This is item three</div>
<div>This is item four</div>
</div>
</div>
https://jsfiddle/dvekrebv/6/
本文标签: jqueryJavascript Click event on input fieldStack Overflow
版权声明:本文标题:jquery - Javascript Click event on input field - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743906961a2559698.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论