jQuery TextBox自动完成条


Posted in Javascript onJuly 22, 2009

代码如下:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default3.aspx.cs" Inherits="Default3" %> <!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 runat="server"> 
<title>无标题页</title> 
<style type="text/css"><!-- 
.mouseEnter 
{ 
background-color: Yellow; 
} 
--></style><style type="text/css" bogus="1"> .mouseEnter 
{ 
background-color: Yellow; 
} 
</style> 
<script type="text/javascript" src="SCRIPT/jquery-1.3.2-vsdoc2.js" src="SCRIPT/jquery-1.3.2-vsdoc2.js"></script> 
<script type="text/javascript"><!-- 
$(function(){ 
$("#result").css("position","absolute"); 
var offset =$("#TextBox1").offset(); 
$("#result").css({left: offset.left +"px",top: offset.top + $("#TextBox1").height() + "px"}); 
}); 
// --></script> 
</head> 
<body > 
<form id="form1" runat="server" onsubmit="alert($('#TextBox1').val());"> 
<center><asp:TextBox ID="TextBox1" runat="server" width="137px" ></asp:TextBox></center> 
<div id="result" style="width: 147px;"> 
<table style="width: 100%; border-style: none solid solid solid; border-width: 1px; 
border-color: #00FF00"> 
<tbody id="mytable"> 
</tbody> 
</table> 
 </div> 
</form> 
<script type="text/javascript"><!-- 
var size = 0; //每次真实取到的数据条目数(最大10) 
var index = -1 ;//计算keydown事件:td索引; 
function setTdEvent(){//为生成的TD设置事件 
//点击效果 
$("#mytable>tr>td").click(function(){ 
$("#TextBox1").val($(this).text()); 
}); 
//选择高亮效果 
$("#mytable>tr >td").hover(function(){ 
$(this).addClass("mouseEnter"); 
},function(){ 
$(this).removeClass("mouseEnter"); 
}); 
} 

function setTD(text){ 
//$("tr:even").css("backgroundColor","blue"); 
return "<tr><td style='border: 0px none #FFFFFF;width:100%'>" + text + "</td></tr>"; 
} 
function setTable(msg) 
{ 
var tbody = $("#mytable"); 
var texts = msg.split(";"); 
var str =""; 
size = texts.length; 
for(var i=0;i<texts.length;i++) 
{ 
str += setTD(texts[i]); 
} 
tbody.html(str); 
setTdEvent() 
$("#div1").show("fast"); 
} 
function setKeyDown(str) 
{ 
$("#mytable>tr>td:eq(" + index + ")").removeClass("mouseEnter"); 
if(str == "+") 
{ 
index = (++index) % size; 
} 
else if("-") 
{ 
index =(--index + size) % size; 
} 
try{ 
$("#mytable>tr>td:eq(" + index + ")").addClass("mouseEnter"); 
}catch(e){ 
alert(e); 
} 
} 
$(function(){ 
$("#TextBox1").bind("propertychange",function(){ 
$("#div1").hide("fast").html(""); 
index = -1; 
$.ajax({ 
type: "POST", 
url: "Suggest.ashx", 
data: "word="+$("#TextBox1").val()+"&time="+new Date().toLocaleTimeString(), 
success: function(msg){ 
setTable( msg ); 
} 
}); 
}); 
$("#TextBox1").bind("keydown",function(event){ 
if( event.keyCode == 38 ) 
{ 
setKeyDown("-"); 
} 
else if(event.keyCode == 40) 
{ 
setKeyDown("+"); 
} 
else if(event.keyCode == 13 && index != -1) 
{ 
$("#TextBox1").val( $("#mytable>tr>td:eq(" + index + ")").text()); 
} 
}); 
}); 
// --></script> 
</body> 
</html>

Ajax调用的一般处理程序为:
<%@ WebHandler Language="C#" Class="Suggest" %> using System; 
using System.Web; 
using System.Linq; 
using System.Xml; 
using System.Xml.Linq; 
public class Suggest : IHttpHandler 
{ 
public void ProcessRequest(HttpContext context) 
{ 
HttpResponse Response = context.Response; 
Response.Charset = "gb2312"; 
Response.ContentEncoding = System.Text.Encoding.UTF8; 
Response.ContentType = "text/plain"; 
Response.StatusCode = 200; 
string start = context.Request.Params["word"].ToString(); 
Response.Write(GetSuggest(start)); 
Response.Flush(); 
} 
public bool IsReusable 
{ 
get 
{ 
return false; 
} 
} 
/// <summary> 
/// 获取响应字符串 
/// </summary> 
/// <param name="start">查询起始字符串</param> 
/// <returns>响应字符串</returns> 
private string GetSuggest(string start) 
{ 
XElement root = XElement.Load(AppDomain.CurrentDomain.SetupInformation.ApplicationBase + "Suggest.xml"); 
System.Collections.Generic.IEnumerable<string> 
q = (from r in root.Elements() 
where (r.Name).ToString().ToLower().StartsWith(start.ToLower()) 
select r.Name.ToString()).Take(5); 
System.Text.StringBuilder sb = new System.Text.StringBuilder(); 
foreach (string w in q) 
{ 
sb.Append(w + ";"); 
} 
if (sb.Length != 0) 
sb.Remove(sb.Length - 1, 1); 
return sb.ToString(); 
} 
}

其中xml文档其实也不是什么标准的xml文档,就是拿来存储数据,练习练习刚学的Linq to XML。由于不想建表,本人也许有点懒惰吧,xml文档内容都是随机产生的:所以下面的效果显示的结果都是随机生成的;不说了。来个图例:
jQuery TextBox自动完成条
Javascript 相关文章推荐
javascript 跳转代码集合
Dec 03 Javascript
10个实用的脚本代码工具
May 04 Javascript
js/jquery去掉空格,回车,换行示例代码
Nov 05 Javascript
js 点击页面其他地方关闭弹出层(示例代码)
Dec 24 Javascript
浅谈Sizzle的“编译原理”
Apr 14 Javascript
悬浮广告方法日常收集整理
Mar 18 Javascript
window.close(); 关闭浏览器窗口js代码的总结介绍
Jul 14 Javascript
JS实现物体带缓冲的间歇运动效果示例
Dec 22 Javascript
vue router自动判断左右翻页转场动画效果
Oct 10 Javascript
3种vue路由传参的基本模式
Feb 22 Javascript
使用typescript构建Vue应用的实现
Aug 26 Javascript
详解ES6中class的实现原理
Oct 03 Javascript
JavaScript 动态生成方法的例子
Jul 22 #Javascript
模仿jQuery each函数的链式调用
Jul 22 #Javascript
js 代码集(学习js的朋友可以看下)
Jul 22 #Javascript
javascript Base类 包含基本的方法
Jul 22 #Javascript
javascript 表单规则集合对象
Jul 21 #Javascript
一个可以随意添加多个序列的tag函数
Jul 21 #Javascript
一个cssQuery对象 javascript脚本实现代码
Jul 21 #Javascript
You might like
解决GD中文乱码问题
2007/02/14 PHP
php Undefined index和Undefined variable的解决方法
2008/03/27 PHP
解析mysql left( right ) join使用on与where筛选的差异
2013/06/18 PHP
php生成图形验证码几种方法小结
2013/08/15 PHP
php数组使用规则分析
2015/02/27 PHP
Yii框架分页技术实例分析
2019/08/30 PHP
firefox下frameset取不到值的解决方法
2010/09/06 Javascript
浅谈NodeJS中require路径问题
2015/05/07 NodeJs
JS实现鼠标滑过折叠与展开菜单效果代码
2015/09/06 Javascript
AngularJS 遇到的小坑与技巧小结
2016/06/07 Javascript
NodeJS使用formidable实现文件上传
2016/10/27 NodeJs
如何解决jQuery EasyUI 已打开Tab重新加载问题
2016/12/19 Javascript
JS简单实现自定义右键菜单实例
2017/05/31 Javascript
Express+Nodejs 下的登录拦截实现代码
2017/07/01 NodeJs
JS实现访问DOM对象指定节点的方法示例
2018/04/04 Javascript
Vue封装的可编辑表格插件方法
2018/08/28 Javascript
更改BootStrap popover的默认样式及popover简单用法
2018/09/13 Javascript
JavaScript事件对象深入详解
2018/12/30 Javascript
[01:32]寻找你心中的那团火 DOTA2 TI9火焰传递活动今日开启
2019/05/16 DOTA
学习python类方法与对象方法
2016/03/15 Python
深入浅析Python中list的复制及深拷贝与浅拷贝
2018/09/03 Python
Python 20行简单实现有道在线翻译的详解
2019/05/15 Python
python sorted函数的小练习及解答
2019/09/18 Python
如何分离django中的媒体、静态文件和网页
2019/11/12 Python
创建Shapefile文件并写入数据的例子
2019/11/26 Python
pytorch实现用CNN和LSTM对文本进行分类方式
2020/01/08 Python
Python如何在main中调用函数内的函数方式
2020/06/01 Python
快速创建python 虚拟环境
2020/11/28 Python
如何写出好的Java代码
2014/04/25 面试题
营销与策划专业毕业生求职信
2013/11/01 职场文书
大学秋游活动方案
2014/02/11 职场文书
《蒲公英》教学反思
2014/02/28 职场文书
计算机系统管理员求职信
2014/06/20 职场文书
汽车转让协议书
2015/01/29 职场文书
事业单位年度考核个人总结
2015/02/12 职场文书
教师廉政准则心得体会
2016/01/20 职场文书