视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
JavaScript实现搜索框的自动完成功能(一)_javascript技巧
2020-11-27 20:51:19 责编:小采
文档


在很多需要搜索的网站, 都会有一个自动完成的搜索框. 方便用户查找他们想要的搜索词. 帮助用户快速找到自己想要的结果. 这种方式是比较友好的. 所以是比较提倡使用的.

先给大家展示下效果图:

  实现这个功能需要服务端配合。客户端通过脚本来展示从服务端取得的数据。

  先看客户端的HTML:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>搜索词自动完成</title> 
<style type="text/css">
#search{ text-align: center; position:relative; } 
.autocomplete{ border: 1px solid #9ACCFB; background-color: white; text-align: left; } 
.autocomplete li{ list-style-type: none; } .clickable { cursor: default; } 
.highlight { background-color: #9ACCFB; } 
</style> 
<script type="text/javascript" src="jquery.js">
</script> 
<script type="text/javascript"> 
$(function(){ 
//取得div层 
var $search = $('#search'); 
//取得输入框JQuery对象 
var $searchInput = $search.find('#search-text'); 
//关闭浏览器提供给输入框的自动完成 
$searchInput.attr('autocomplete','off'); 
//创建自动完成的下拉列表,用于显示服务器返回的数据,插入在搜索按钮的后面,等显示的时候再调整位置 
var $autocomplete = $('<div></div>') .hide() .insertAfter('#submit'); 
//清空下拉列表的内容并且隐藏下拉列表区 
var clear = function(){ $autocomplete.empty().hide(); }; 
//注册事件,当输入框失去焦点的时候清空下拉列表并隐藏 
$searchInput.blur(function(){ setTimeout(clear,500); }); 
//下拉列表中高亮的项目的索引,当显示下拉列表项的时候,移动鼠标或者键盘的上下键就会移动高亮的项目,想百度搜索那样
 var selectedItem = null; 
 //timeout的ID var timeoutid = null; 
 //设置下拉项的高亮背景 
 var setSelectedItem = function(item){ 
 //更新索引变量 selectedItem = item ; 
 //按上下键是循环显示的,小于0就置成最大的值,大于最大值就置成0 
 if(selectedItem < 0){ 
 selectedItem = $autocomplete.find('li').length - 1; 
 } 
 else if(selectedItem > $autocomplete.find('li').length-1 ) { selectedItem = 0; } 
 //首先移除其他列表项的高亮背景,然后再高亮当前索引的背景 
 $autocomplete.find('li').removeClass('highlight') .eq(selectedItem).addClass('highlight'); }; 
 var ajax_request = function(){ 
 //ajax服务端通信 $.ajax({ 'url':'/test/index.jsp', 
 //服务器的地址 'data':{'search-text':$searchInput.val()}, 
 //参数 'dataType':'json', 
 //返回数据类型 'type':'POST', 
 //请求类型 'success':function(data){ if(data.length) { 
 //遍历data,添加到自动完成区 $.each(data, function(index,term) { 
 //创建li标签,添加到下拉列表中 $('<li></li>').text(term).appendTo($autocomplete) .addClass('clickable') 
 .hover(function(){ 
 //下拉列表每一项的事件,鼠标移进去的操作 
 $(this).siblings().removeClass('highlight'); 
 $(this).addClass('highlight'); 
 selectedItem = index; },function(){ 
 //下拉列表每一项的事件,鼠标离开的操作 $(this).removeClass('highlight'); 
 //当鼠标离开时索引置-1,当作标记 selectedItem = -1; }) .click(function(){ 
 //鼠标单击下拉列表的这一项的话,就将这一项的值添加到输入框中 $searchInput.val(term); 
 //清空并隐藏下拉列表 $autocomplete.empty().hide(); }); });
 //事件注册完毕 
 //设置下拉列表的位置,然后显示下拉列表 
 var ypos = $searchInput.position().top; 
 var xpos = $searchInput.position().left; 
 $autocomplete.css('width',$searchInput.css('width')); 
 $autocomplete.css({'position':'relative','left':xpos + "px",'top':ypos +"px"}); 
 setSelectedItem(0); 
 //显示下拉列表 
 $autocomplete.show(); 
 } 
 } 
 }); 
 }; 
 //对输入框进行事件注册 
 $searchInput .keyup(function(event) { 
 //字母数字,退格,空格 
 if(event.keyCode > 40 || event.keyCode == 8 || event.keyCode ==32) { 
 //首先删除下拉列表中的信息 
 $autocomplete.empty().hide(); 
 clearTimeout(timeoutid); 
 timeoutid = setTimeout(ajax_request,100); 
 } 
 else if(event.keyCode == 38){ 
 //上 //selectedItem = -1 代表鼠标离开 
 if(selectedItem == -1){ 
 setSelectedItem($autocomplete.find('li').length-1); 
 } else { 
 //索引减1 setSelectedItem(selectedItem - 1); 
 } 
 event.preventDefault(); 
 } 
 else if(event.keyCode == 40) { 
 //下 //selectedItem = -1 代表鼠标离开 if(selectedItem == -1){ setSelectedItem(0); } 
 else { 
 //索引加1 setSelectedItem(selectedItem + 1); 
 } event.preventDefault(); 
 } 
 }) 
 .keypress(function(event){ //enter键 if(event.keyCode == 13) { 
 //列表为空或者鼠标离开导致当前没有索引值 if($autocomplete.find('li').length == 0 || selectedItem == -1) 
 { return; } 
 $searchInput.val($autocomplete.find('li').eq(selectedItem).text()); 
 $autocomplete.empty().hide(); event.preventDefault(); } }) .keydown(function(event){ 
 //esc键 if(event.keyCode == 27 ) { $autocomplete.empty().hide(); 
 event.preventDefault(); } }); 
 //注册窗口大小改变的事件,重新调整下拉列表的位置 
 $(window).resize(function() { 
 var ypos = $searchInput.position().top; 
 var xpos = $searchInput.position().left; 
 $autocomplete.css('width',$searchInput.css('width')); 
 $autocomplete.css({'position':'relative','left':xpos + "px",'top':ypos +"px"}); 
 }); 
 }); 
 </script> 
 </head> 
 <body> 
 <div id = "search"> 
 <label for="search-text">请输入关键词</label>
 <input type="text" id="search-text" name="search-text" /> 
 <input type="button" id="submit" value="搜索"/> 
 </div> 
 </body> 
 </html>

服务端的代码,我们这里选择JSP,也可以使用PHP,服务端无所谓,关键是传送数据。

代码如下:

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> 
<% 
String []words = {"amani","abc","apple","abstract","an","bike","byebye", 
"beat","be","bing","come","cup","class","calendar","china"}; 
if(request.getParameter("search-text") != null) { 
String key = request.getParameter("search-text"); 
if(key.length() != 0){ 
String json="["; 
for(int i = 0; i < words.length; i++) { 
if(words[i].startsWith(key)){ 
json += "\""+ words[i] + "\"" + ","; 
} 
} 
json = json.substring(0,json.length()-1>0?json.length()-1:1); 
json += "]"; 
System.out.println("json:" + json); 
out.println(json); 
} 
} 
%>

整个过程思路其实挺清晰的,首先在输入框上注册keyup事件,然后在事件中通过ajax获取json对象。取得数据后,每一项数据创建一个li标签,在标签上注册click事件,这样当我们点击每一项的时候,就可以响应事件。键盘导航的关键是记录当前高亮的索引值,根据索引值来调整背景高亮。显示下拉列表的位置要根据输入框的位置来设置,当浏览器的大小改变时,随时调整下拉列表的位置。

以上所述是小编给大家介绍的JavaScript实现搜索框的自动完成功能(一),更多相关内容请关注PHP中文网(www.gxlcms.com)!

下载本文
显示全文
专题