关键词匹配搜索仿百度

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>关键词匹配搜索仿百度</title>
<meta name="description" content=" 内容介绍不超过100个中文">
<meta name="keywords" content=" 内容相关关键词3-5个">
<style>
body, ul, li { margin: 0; padding: 0;}
body{ font-size:12px; font-family:sumsun,arial;background:#FFFFFF;}
.gover_search{ position:relative; z-index:99; height:63px; padding:15px 0 0 20px; border:1px solid #b8cfe6; border-bottom:0; background:url(../images/gover_search_bg.gif) repeat-x 0 0;}
.gover_search_form{height:36px;}
.gover_search .search_t{ float:left; width:112px; line-height:26px; color:#666;}
.gover_search .input_search_key{ float:left; width:462px; height:18px; padding:3px; margin-right:5px; border:1px solid #ccc; line-height:18px; background:#fff;}
.gover_search .search_btn{ float:left; width:68px; height:26px; overflow:hidden; border:1px solid #ccc; text-align:center; color:#ff3300; letter-spacing:5px; background:url(../images/gover_search_bg.gif) no-repeat 0 -79px; cursor:pointer; font-weight:bold;}
.gover_search .search_suggest{ position:absolute; z-index:999; left:132px; top:41px; width:468px; border:1px solid #ccc;border-top:none; display:none;color:#004080; }
.gover_search .search_suggest li{height:24px; overflow:hidden; padding-left:3px; line-height:24px; background:#fff; cursor:default;}
.gover_search .search_suggest li.hover{background:#ddd;}
.num_right{float:right;text-align:right;line-height:24px;padding-right:10px}

</style>


</head>

<body>

	<div class="gover_search">
    	<div class="gover_search_form clearfix">
            <span class="search_t">关键词匹配搜索</span>
            <input type="text" class="input_search_key" id="gover_search_key" value="请输入关键词直接搜索" />
            <button type="submit" class="search_btn" οnclick="if($('#gover_search_key').val()){window.open('http://www.baidu.com');}">搜索</button>
            <div class="search_suggest" id="gov_search_suggest">
                <ul>
                </ul>
            </div>
        </div>
    </div>
<script type="text/javascript" src="http://jt.875.cn/js/jquery.js"></script>
<script type="text/javascript" src="http://jt.875.cn/js/jquery.animate-colors-min.js"></script>
<script type="text/javascript">

//实现搜索输入框的输入提示js类
function oSearchSuggest(searchFuc){
	var input = $('#gover_search_key');
	var suggestWrap = $('#gov_search_suggest');
	var key = "";
	var init = function(){
		input.bind('keyup',sendKeyWord);
		//按下回车后开始搜索
		input.bind('keydown',function(e){
			if(e && e.keyCode == 13) {
				//如果有提示关键字是hover状态,则搜索该提示关键字
				if (suggestWrap.css('display')=='block' && suggestWrap.find("li.hover").length > 0) {
					input.val(suggestWrap.find("li.hover label").text());
				}
				$('button.search_btn').click();
			}
		});
		input.bind('blur',function(){setTimeout(hideSuggest,200);});
		$('button.search_btn').click(function(){//增加为输入效果
			var v = input.val();
			if (!v || $.trim(v) == '') {
				input.animate({'backgroundColor': '#fdce9c'}, 750, function(){
					input.animate({'backgroundColor': '#FFFFFF'}, 750);
				});
				return;
			}
			window.open('http://www.baidu.com');
		});
	}
	var hideSuggest = function(){
		suggestWrap.hide();
	}
	
	//发送请求,根据关键字到后台查询
	var sendKeyWord = function(event){
		//回车直接忽略
		if (event && event.keyCode == 13) return;

		//键盘选择下拉项
		if(suggestWrap.css('display')=='block'&&(event.keyCode == 38||event.keyCode == 40)){
			var current = suggestWrap.find('li.hover');
			if(event.keyCode == 38){
				if(current.length>0){
					var prevLi = current.removeClass('hover').prev();
					if(prevLi.length>0){
						prevLi.addClass('hover');
						input.val(prevLi.find('label').text());
					}
				}else{
					var lastLi = suggestWrap.find('li:last');
					lastLi.addClass('hover');
					input.val(lastLi.find('label').text());
				}
				
			}else if(event.keyCode == 40){
				if(current.length>0){
					var nextLi = current.removeClass('hover').next();
					if(nextLi.length>0){
						nextLi.addClass('hover');
						input.val(nextLi.find('label').text());
					}
				}else{
					var firstLi = suggestWrap.find('li:first');
					firstLi.addClass('hover');
					input.val(firstLi.find('label').text());
				}
			}
			
		//输入字符
		}else{ 
			var valText = $.trim(input.val());
			if(valText ==''||valText==key){
				return;
			}
			searchFuc(valText);
			key = valText;
		}			
		
	}
	//请求返回后,执行数据展示
	this.dataDisplay = function(data){
		if(data.length<=0){
            suggestWrap.hide();
			return;
		}
		
		//往搜索框下拉建议显示栏中添加条目并显示
		suggestWrap.find('ul').empty();
		for(var i=0; i<data.length; i++){
			suggestWrap.find('ul').append('<li>' + data[i] + '</li>');
		}
		suggestWrap.show();
		
		//为下拉选项绑定鼠标事件
		suggestWrap.find('li').hover(function(){
				suggestWrap.find('li').removeClass('hover');
				$(this).addClass('hover');
		
			},function(){
				$(this).removeClass('hover');
		}).click(function(){
			input.val($(this).find('label').text());
			//点击后开始搜索
			$('button.search_btn').click();
		});
	}
	init();
};

//实例化输入提示的JS,参数为进行查询操作时要调用的函数名
var searchSuggest =  new oSearchSuggest(sendKeyWordToBack);

//这是一个模似函数,实现向后台发送ajax查询请求,并返回一个查询结果数据,传递给前台的JS,再由前台JS来展示数据。本函数由程序员进行修改实现查询的请求
//参数为一个字符串,是搜索输入框中当前的内容
function sendKeyWordToBack(keyword){
	   /*  var obj = {
			    "keyword" : keyword
			 };
			 $.ajax({
					   type: "POST",
					   url: "${ctx}/front/suqiu2/search/prompt-keyword.action",
					   async:false,
					   data: obj,
					   dataType: "json",
					   success: function(data){
						 //var json = eval("("+data+")");
						 var key=data.split(",");
						 var aData = [];
						 for(var i=0;i<key.length;i++){
								//以下为根据输入返回搜索结果的模拟效果代码,实际数据由后台返回
							if(key[i]!=""){
								  aData.push(key[i]);
							}
						 }
						//将返回的数据传递给实现搜索输入框的输入提示js类
						 searchSuggest.dataDisplay(aData);
					   }
		 });	  */
			 
				//以下为根据输入返回搜索结果的模拟效果代码,实际数据由后台返回
				var aData = [];
				aData.push('<span class="num_right">约100个</span><label>'+keyword+'返回数据1'+'</label>');
				aData.push('<span class="num_right">约200个</span><label>'+keyword+'返回数据2'+'</label>');
				aData.push('<span class="num_right">约100个</span><label>'+keyword+'返回数据3'+'</label>');
				aData.push('<span class="num_right">约50000个</span><label>'+keyword+'返回数据4'+'</label>');
				aData.push('<span class="num_right">约1044个</span><label>'+keyword+'2012是真的'+'</label>');
				aData.push('<span class="num_right">约100个</span><label>'+keyword+'2012是假的'+'</label>');
				aData.push('<span class="num_right">约100个</span><label>'+keyword+'2012是真的'+'</label>');
				aData.push('<span class="num_right">约100个</span><label>'+keyword+'2012是假的'+'</label>');
				//将返回的数据传递给实现搜索输入框的输入提示js类
				searchSuggest.dataDisplay(aData);
	
}

</script>
</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值