上一篇文章讲解了jquery-ui实现文本框输入提示功能的做法,后来又发现了一个挺好用的能实现文本框输入提示功能的jquery插件jquery-autocomplete,这次讲一下他的用法。
引入所需文件
<script type="text/javascript" src="JS/jquery-1.8.2.min.js"></script>
<script type="text/javascript" src="JS/jquery.autocomplete.min.js"></script>
<link href="CSS/jquery.autocomplete.css" rel="stylesheet" />
动态单属性数据源
前台代码:
$(document).ready(function () {
$("#txtAutoComplete").autocomplete("AutoComplete.ashx", {
max: 10, //列表里的条目数
minChars: 1, //自动完成激活之前填入的最少字符
scrollWidth: 173, //提示的宽度,溢出隐藏
scrollHeight: 200, //提示的高度,溢出显示滚动条
scroll: true, //是否显示滚动条
matchContains: true, //包含匹配,是否只显示匹配项
autoFill: false, //自动填充
//此处实际请求的URL为"AutoComplete.ashx?q='[你在txtAutoComplete中输入的值]'&action='autoComplete'&value='guo'"
extraParams: { action: "autoComplete", value: "guo" },
//格式化列表中的条目 row:条目对象,i:当前条目index,max:总条目数
formatItem: function (row, i, max) {
//【不用转化为js对象,但必须返回row.toString()】
return row.toString();
},
//配合formatItem使用,作用在于,由于使用了formatItem,所以显示的条目内容有所改变,
//而我们要匹配的是原始的数据,所以用formatMatch做一个调整,使之匹配原始数据
formatMatch: function (row, i, max) {
//【不用转化为js对象,但必须返回row.toString()】
return row.toString();
},
//设置用户选择某一条目后文本框显示的内容
formatResult: function (row) {
//【不用转化为js对象,但必须返回row.toString()】
return "文本框显示的结果:" + row.toString();
}
}).result(function (event, row, formatted) {
//获取用户选择的条目
alert(row.toString());
});
});
<body>
<form id="form1" runat="server">
请输入:<input type="text" id="txtAutoComplete" />
</form>
</body>
AutoComplete.ashx后台代码:
public class AutoComplete : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
//text表示用户在文本框输入的内容
string text = context.Request.QueryString["q"];
string action = context.Request.QueryString["action"];
string value = context.Request.QueryString["value"];
<!--各项之间必须用"\n"隔开,不能用","隔开-->
string strResult = "guo\ntong\nchang\nwang\nhao\nbang";
context.Response.Write(strResult);
}
public bool IsReusable
{
get
{
return false;
}
}
}
动态多属性数据源
前台代码:
$(document).ready(function () {
$("#txtAutoComplete").autocomplete("AutoComplete.ashx", {
max: 10, //列表里的条目数
minChars: 1, //自动完成激活之前填入的最少字符
width: 173, //提示的宽度,溢出隐藏
scrollHeight: 200, //提示的高度,溢出显示滚动条
scroll: true, //是否显示滚动条
matchContains: true, //包含匹配,是否只显示匹配项
autoFill: false, //自动填充
//此处实际请求的URL为"AutoComplete.ashx?q='[你在txtAutoComplete中输入的值]'&action='autoComplete'&value='guo'"
extraParams: { action: "autoComplete", value: "guo" },
//格式化列表中的条目,使其以自定义格式显示
//row:条目对象,i:当前条目index,max:总条目数
formatItem: function (row, i, max) {
//转换成js对象 【不同点1】
var obj = eval('(' + row + ')');
return i + "/" + max + ": " + obj.key + obj.value;
},
//配合formatItem使用,作用在于,由于使用了formatItem,所以显示的条目内容有所改变,
//而我们要匹配的是原始的数据,所以用formatMatch做一个调整,使之匹配原始数据
formatMatch: function (row, i, max) {
//转换成js对象
//获取对象中的某一属性时,名称严格区分大小写
var obj = eval('(' + row + ')');
return "Match:" + obj.key + row.value;
},
//设置用户选择某一条目后文本框显示的内容
formatResult: function (row) {
//转换成js对象
var obj = eval('(' + row + ')');
return "文本框显示的结果:" + obj.key;
}
}).result(function (event, row, formatted) {
//获取用户选择的条目,并转换成js对象
var obj = eval('(' + row + ')');
alert(obj.key);
});
});
<body>
<form id="form1" runat="server">
请输入:<input type="text" id="txtAutoComplete" />
</form>
</body>
AutoComplete.ashx后台代码:
public class AutoComplete : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
//text表示用户在文本框输入的内容
string text = context.Request.QueryString["q"];
string action = context.Request.QueryString["action"];
string value = context.Request.QueryString["value"];
<!--数据格式【不同点2】-->
<!--各项之间必须用"\n"隔开,不能用","隔开-->
string strResult = "{key:\"one\",value:\"第一\"}\n"+
"{key:\"two\",value:\"第二\"}\n"+
"{key:\"three\",value:\"第三\"}\n"+
"{key:\"four\",value:\"第四\"}\n"+
"{key:\"five\",value:\"第五\"}\n"+
"{key:\"six\",value:\"第六\"}";
context.Response.Write(strResult);
}
public bool IsReusable
{
get
{
return false;
}
}
}
ajax动态绑定数据源
前台代码:
function bindAutoComplete() {
$.ajax({
type: "POST",
contentType: "application/json",
url: "AutoComplete.aspx/GetHintsInfo",
data: "{no:'aaa'}",
dataType: "json",
success: function (msg) {
var datas = eval("(" + msg.d + ")");
$("#txtProjectNO").autocomplete(datas, {
formatItem: function (row, i, max) {
return "<table width='100px'><tr><td align='left'>" + row.ProjectNo + "</td><td align='right'><font style='color: #009933; font-family: 黑体; font-style: italic'>" + row.ProjectName + "</font> </td></tr></table>";
},
formatMatch: function (row, i, max) {
return row.ProjectNo;
}
}).result(function (event, item) {
$("#txtProjectName").val(item.ProjectName);
$("#txtDesigner").val(item.Designer);
$("#txtBudget").val(item.Budget);
});
}
});
}
AutoComplete.aspx后台代码:
[WebMethod]
public static string GetAllHintsSomeField(string no)
{
List<ProjectInfo> list = new List<ProjectInfo>();
BLL.CommonBLL commonBLL = new BLL.CommonBLL();
string where = "IsClosed=0";
DataTable dt = commonBLL.GetList("View_Project", where);
for (int i = 0; i < dt.Rows.Count; i++)
{
list.Add(new ProjectInfo()
{
ProjectNo = dt.Rows[i]["ProjectNo"].ToString(),
ProjectName = dt.Rows[i]["ProjectName"].ToString(),
Designer = dt.Rows[i]["Designer"].ToString(),
Budget = dt.Rows[i]["Budget"].ToString()
});
}
DataContractJsonSerializer serializer = new DataContractJsonSerializer(list.GetType());
using (MemoryStream ms = new MemoryStream())
{
serializer.WriteObject(ms, list);
return System.Text.Encoding.UTF8.GetString(ms.ToArray());
}
}
extraParams动态传递参数
autoComplete可以利用extraParams传递参数,如:extraParams:{ para1:‘参数1’, para2:‘参数2’ },
但是如果将动态获取的值作为参数值却无法达到目的,如:extraParams:{ userName:$("#userName").val(), age:$("#age").val() },
改进成将方法作为参数值,然后再把实际参数值当做方法的返回值就可以了,如:
extraParams:{ userName:function(){ return $("#userName").val(); }, age:function(){ return $("#age").val(); } },
$(document).ready(function () {
//[AutoComplete]1、禁止输入逗号
$(".userAC,.domainGroupInfoAC").keydown(function () {
if (event.keyCode == 188) {
return false;
}
});
//[AutoComplete]2、对新增的成员控件绑定自动完成功能
if ($(".userAC").autocomplete) {
var url = '@Url.Content("~/ACUser/GetUserList/")';
$(".userAC").autocomplete(url, {
width: 300,
minChars: 1,
cacheLength: 0,
extraParams: {
userType: function () { return $("input[name='ApplyUsersType']:checked").val();} },
multiple: true,
mustMatch: true,
formatItem: deptManagerACFormatItem,
formatResult: deptManagerACFormatResult
}).result(function (event, item) {
//showUserMessage();
});
}
});
页面加载完毕之后克隆autocomplete绑定的控件会出问题
在工作中经常需要生成动态增加行的表格,此次需要对表格中的文本框绑定autocomplete功能。
表格初始时只有一行,而且已绑定autocomplete功能,此时当我们通过克隆第一行来增加新行时会出现问题。
折腾了半天,从种种迹象中发现事件其实有绑定,但都绑定在了一开始复制的那一行上面去了,再看看绑定后生成的源代码,其实JQuery生成的对像都有一个类似jQuery17206059004419403464="3"的属性;原来在复制行时把这个属性也复制了,导致后面的绑定错位;我们需要用文本框标签来替换将第一行的autocomplete文本框,这样新行中的文本框和第一行就没有任何关系了,然后再对所有控件绑定autocomplete。
//添加节点tr
$("#btnAddAddNode").click(function () {
var currentMaxStep = $("#addNodeTable tr").filter(".nodeTr").size();
var nextStep = currentMaxStep + 1;
var firstTr = $("#addNodeTable tr.nodeTr:eq(0)");
var newTr = firstTr.clone(true);
//修改id
newTr.attr("id", "addNodeTr" + nextStep);
//设置序号
newTr.find("td:eq(0)").text(nextStep);
//设置节点名称
var selectText = newTr.find("select:eq(0)").find("option:selected").text();
newTr.find("input:eq(0)").val(selectText + "审批");
//设置审批人
newTr.find("td:eq(3)").html('<input type="text" class="userAC" value="" />');
newTr.appendTo($("#addNodeTable"));
//由于添加了class=userAC的控件,所以要重新绑定
bindAutoComplete();
});
function bindAutoComplete(_this) {
//[AutoComplete]1、禁止输入逗号
$(".userAC").keydown(function () {
if (event.keyCode == 188) {
return false;
}
});
//[AutoComplete]2、对新增的成员控件绑定自动完成功能
if ($(".userAC").autocomplete) {
var url = '@Url.Content("~/ACUser/GetUserList/")';
$(".userAC").autocomplete(url, {
width: 300,
multiple: false,
mustMatch: true,
formatItem: deptManagerACFormatItem,
formatResult: deptManagerACFormatResult
}).result(function (event, item) {
//showUserMessage();
});
}
}