jQuery下拉搜索是一种常见的前端交互功能,它允许用户在一个下拉列表中输入文本,系统会根据输入的文本实时过滤并显示匹配的选项。这种功能通常用于提升用户体验,减少用户选择的时间。
以下是一个简单的jQuery下拉搜索示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>jQuery Dropdown Search</title>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<style>
.searchable-dropdown {
width: 200px;
position: relative;
display: inline-block;
}
.searchable-dropdown input[type="text"] {
width: 100%;
padding: 10px;
box-sizing: border-box;
}
.searchable-dropdown .dropdown-list {
position: absolute;
width: 100%;
border: 1px solid #ccc;
border-top: none;
display: none;
}
.searchable-dropdown .dropdown-list li {
padding: 10px;
cursor: pointer;
}
.searchable-dropdown .dropdown-list li:hover {
background-color: #f1f1f1;
}
</style>
</head>
<body>
<div class="searchable-dropdown">
<input type="text" id="search-box" placeholder="Search...">
<ul class="dropdown-list" id="options-list">
<li>Apple</li>
<li>Banana</li>
<li>Cherry</li>
<li>Orange</li>
<li>Pineapple</li>
</ul>
</div>
<script>
$(document).ready(function() {
$('#search-box').on('input', function() {
var searchValue = $(this).val().toLowerCase();
$('#options-list li').each(function() {
var optionText = $(this).text().toLowerCase();
if (optionText.indexOf(searchValue) > -1) {
$(this).show();
} else {
$(this).hide();
}
});
});
$('#search-box').on('focus', function() {
$('#options-list').show();
});
$('#search-box').on('blur', function() {
setTimeout(function() {
$('#options-list').hide();
}, 200);
});
$('#options-list li').on('click', function() {
$('#search-box').val($(this).text());
});
});
</script>
</body>
</html>
通过以上方法,可以有效地实现和优化jQuery下拉搜索功能。
云+社区沙龙online第5期[架构演进]
Elastic 实战工作坊
Elastic 实战工作坊
数智话
企业创新在线学堂
Elastic Meetup
Elastic 实战工作坊
云+社区技术沙龙[第20期]
领取专属 10元无门槛券
手把手带您无忧上云