JS实现输入框类似百度搜索的智能提示效果

转:https://blog.csdn.net/yedajiang44/article/details/72758269

1.html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
	<head>
		<title></title>
		<style type="text/css">
			.search {
				left: 0;
				position: relative;
			}			
			#auto_div {
				display: none;
				width: 300px;
				border: 1px #74c0f9 solid;
				background: #FFF;
				position: absolute;
				top: 24px;
				left: 0;
				color: #323232;
			}
		</style>
		<script src="https://cdn.bootcss.com/jquery/1.11.3/jquery.min.js"></script>
		<script type="text/javascript">
			//测试用的数据,这里可以用AJAX获取服务器数据
			var test_list = ["小张", "小苏", "小杨", "老张", "老苏", "老杨", "老爷爷", "小妹妹", "老奶奶", "大鹏", "大明", "大鹏展翅", "你好", "hello", "hi"];
			var old_value = "";
			var highlightindex = -1; //高亮
			//自动完成
			function AutoComplete(auto, search, mylist) {
				if($("#" + search).val() != old_value || old_value == "") {
					var autoNode = $("#" + auto); //缓存对象(弹出框)
					var carlist = new Array();
					var n = 0;
					old_value = $("#" + search).val();
					for(i in mylist) {
						if(mylist[i].indexOf(old_value) >= 0) {
							carlist[n++] = mylist[i];
						}
					}
					if(carlist.length == 0) {
						autoNode.hide();
						return;
					}
					autoNode.empty(); //清空上次的记录
					for(i in carlist) {
						var wordNode = carlist[i]; //弹出框里的每一条内容
						var newDivNode = $("<div>").attr("id", i); //设置每个节点的id值
						newDivNode.attr("style", "font:14px/25px arial;height:25px;padding:0 8px;cursor: pointer;");
						newDivNode.html(wordNode).appendTo(autoNode); //追加到弹出框
						//鼠标移入高亮,移开不高亮
						newDivNode.mouseover(function() {
							if(highlightindex != -1) { //原来高亮的节点要取消高亮(是-1就不需要了)
								autoNode.children("div").eq(highlightindex).css("background-color", "white");
							}
							//记录新的高亮节点索引
							highlightindex = $(this).attr("id");
							$(this).css("background-color", "#ebebeb");
						});
						newDivNode.mouseout(function() {
							$(this).css("background-color", "white");
						});
						//鼠标点击文字上屏
						newDivNode.click(function() {
							//取出高亮节点的文本内容
							var comText = autoNode.hide().children("div").eq(highlightindex).text();
							highlightindex = -1;
							//文本框中的内容变成高亮节点的内容
							$("#" + search).val(comText);
						})
						if(carlist.length > 0) { //如果返回值有内容就显示出来
							autoNode.show();
						} else { //服务器端无内容返回 那么隐藏弹出框
							autoNode.hide();
							//弹出框隐藏的同时,高亮节点索引值也变成-1
							highlightindex = -1;
						}
					}
				}
				//点击页面隐藏自动补全提示框
				document.onclick = function(e) {
					var e = e ? e : window.event;
					var tar = e.srcElement || e.target;
					if(tar.id != search) {
						if($("#" + auto).is(":visible")) {
							$("#" + auto).css("display", "none")
						}
					}
				}
			}
			$(function() {
				old_value = $("#search_text").val();
				$("#search_text").focus(function() {
					if($("#search_text").val() == "") {
						AutoComplete("auto_div", "search_text", test_list);
					}
				});
				$("#search_text").keyup(function() {
					AutoComplete("auto_div", "search_text", test_list);
				});
			});
		</script>
	</head>

	<body>
		<div class="search">
			<input type="text" id="search_text" />
			<div id="auto_div">
			</div>
		</div>
	</body>
</html>

2.效果

3.说明

(1)效果还是蛮好的,主要用了键盘事件(keyup);

(2)转载:https://blog.csdn.net/yedajiang44/article/details/72758269

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值