Autocomplete 自动补全(Webform实战篇)
开篇语
因为项目中需要用到一个自动补全的功能,功能描述:

需求一:新增收件人的时候,自动下拉显示出数据库中所有的收件人信息(显示的信息包括:姓名-收件地址-联系方式)
需求二:选中一个值得时候,分别赋值到对应文本框(收件人输入框中赋值 姓名,联系方式输入框中赋值 手机号,收件地址输入框中赋值 地址)
解决需求一(因本人比较懒,所以直接选用了一个比较方便的插件:Autocomplete [参考学习地址:http://www.runoob.com/jqueryui/jqueryui-use.html])
实现步骤
步骤① 去官网下载对应版本的包,然后在项目中添加这两个引用即可

步骤② 新建一个一般处理程序

步骤三③ 写查询及转换方法
1 在接口里面新增一个查询方法(接口只定义规则,不做具体实现)

2 继承接口并实现查询方法(因为功能需要,这里查询直接做了拼接,查询出来就是“收件人-地址-联系方式”)

3 方法里面调用这个方法进行json数据转换(通用方法可以直接使用)
// var name = context.Request["name"];
// 查询的参数名称默认为term
string query = context.Request.QueryString["term"];
context.Response.ContentType = "text/javascript";
DataTable sendInfoManage = CMSModelManager.SendInfoManageDAO.Method(query);//调用查询方法,返回一个DataTable
//反序列化
System.Web.Script.Serialization.JavaScriptSerializer serailizer = new System.Web.Script.Serialization.JavaScriptSerializer();
List<Dictionary<string, object>> rows = new List<Dictionary<string, object>>();
Dictionary<string, object> row;
foreach (DataRow dr in sendInfoManage.Rows)
{
row = new Dictionary<string, object>();
foreach (DataColumn col in sendInfoManage.Columns)
{
row.Add(col.ColumnName, dr[col]);
}
rows.Add(row);
} string s= serailizer.Serialize(rows);
context.Response.Write(s);
步骤④ 页面接收返回数据和处理返回数据
$(function() {
var name = $("#ctl00_contentPlace_txtSender").val().trim();
$("#ctl00_contentPlace_txtAddressee").autocomplete({
source: function(request, response) {
$.ajax({
url: "Handler.ashx",//请求地址
type: "post",//请求类型
data: { "name": name },//参数
success: function(data) {
//console.log(data);
response($.map(eval(data), function(item) { //使用该插件必须要用eval()进行处理
//console.log(item);
return {
value: item.show,//赋值到控件上
result: item.show
}
}));
},
error: function(xhr) {
console.log("发生错误");
}
});
},
});
});

下图对应上图的数据呈现过程

页面效果

补充:这个插件默认没有滚动条,需要手动添加样式(最大高度可以自行设定)
<style type="text/css">
.ui-autocomplete {
max-height: 250px;
overflow-y: auto;
/* 防止水平滚动条 */
overflow-x: hidden;
}
/* IE 6 不支持 max-height
* 我们使用 height 代替,但是这会强制菜单总是显示为那个高度
*/
* html .ui-autocomplete {
height: 250px;
}
</style>
解决需求二:特意查了下Autocomplete返回值处理情况,最终选用select做处理,最后请求的ajax改为:
var showName = null;
$(function() {
$("#ctl00_contentPlace_txtAddressee").autocomplete({
source: function(request, response) {
$.ajax({
url: "Handler.ashx", //请求地址
type: "post", //请求类型
data: { "name": $("#ctl00_contentPlace_txtAddressee").val().trim(), "look": $("#ctl00_contentPlace_txtSendCode").val().trim() }, //参数
success: function(data) {
//console.log(data);
response($.map(eval(data), function(item) { //使用该插件必须要用eval()进行处理
//console.log(item);
return {
value: item.show, //赋值到控件上
result: item.show
}
})); },
error: function(xhr) {
console.log("发生错误");
}
});
},
select: function(event, ui) {
var li = (ui.item.label).split("-");
$("#ctl00_contentPlace_txtAddressee").val(li[0]);
console.log(li[0]);
showName = li[0];
$("#ctl00_contentPlace_txtContactInfo").val(li[2]);
$("#ctl00_contentPlace_txtMailingAddress").val(li[1]);
showNames();//可以继续调用其他方法
}
});
});
function showNames() {
console.log(showName);
if (showName != null) {
$("#ctl00_contentPlace_txtAddressee").val("");
$("#ctl00_contentPlace_txtMailContent").val("测试数据");
}
}
效果展示:
选中前

选中后

天了噜,什么,竟然收件人赋值不上,找了半天原因(清空后赋值等等)。。。。。
还是没找到问题,不过因为项目急着测试,就想了个偷懒的办法,用延时再赋值的方式调了下,终于可以了
所以最终版的前台请求如下
var showName = null;
$(function() {
$("#ctl00_contentPlace_txtAddressee").autocomplete({
source: function(request, response) {
$.ajax({
url: "Handler.ashx", //请求地址
type: "post", //请求类型
data: { "name": $("#ctl00_contentPlace_txtAddressee").val().trim(), "look": $("#ctl00_contentPlace_txtSendCode").val().trim() }, //参数
success: function(data) {
//console.log(data);
response($.map(eval(data), function(item) { //使用该插件必须要用eval()进行处理
//console.log(item);
return {
value: item.show, //赋值到控件上
result: item.show
}
}));
},
error: function(xhr) {
console.log("发生错误");
}
});
},
select: function(event, ui) {
var li = (ui.item.label).split("-");
$("#ctl00_contentPlace_txtAddressee").val(li[0]);
console.log(li[0]);
showName = li[0];
$("#ctl00_contentPlace_txtContactInfo").val(li[2]);
$("#ctl00_contentPlace_txtMailingAddress").val(li[1]);
showNames();//可以继续调用其他方法
}
});
});
function showNames() {
if (showName != null) {
setTimeout(function()
{
$("#ctl00_contentPlace_txtAddressee").val(showName); },100);
}
};
最终效果

至此,自动补全已经完成并满足需求,Autocomplete非常灵活,本文只是做了简单阐述和讲解
对Autocomplete插件更多参数和方法说明,请查阅 http://www.runoob.com/jqueryui/api-autocomplete.html
Autocomplete 自动补全(Webform实战篇)的更多相关文章
- jquery.autocomplete自动补全功能
项目实例: 一:js //SupplierAutoComplete.js $().ready(function () { $("#txtSupplier").autocomplet ...
- jQuery AutoComplete 自动补全
jQuery.AutoComplete是一个基于jQuery的自动补全插件.借助于jQuery优秀的跨浏览器特性,可以兼容Chrome/IE/Firefox/Opera/Safari等多种浏览器. 特 ...
- Pig autocomplete 自动补全
在pig的grunt环境下,按TAB键可以自动补全命令,用户可以添加自己的补全信息. 在conf目录下创建autocomplete文件,添加如下内容: hdfs://vm1:8020/ 在grun ...
- Bootstrap Typeahead/Jquery autocomplete自动补全
使用Bootstrap Typeahead 组件: Bootstrap 中的 Typeahead 组件就是通常所说的自动完成 AutoComplete,自动填充. 效果如图所示: 实现方式: 1.引入 ...
- jquery autocomplete自动补全
简单用法: $(function(){ var data = "the People's Republic of China".split(" "); $(&q ...
- WinForm AutoComplete 输入提示、自动补全
一.前言 又临近春节,作为屌丝的我,又要为车票发愁了.记得去年出现了各种12306的插件,最近不忙,于是也着手自己写个抢票插件,当是熟悉一下WinForm吧.小软件还在开发中,待完善后,也写篇博客与大 ...
- jquery autocomplete实现读取sql数据库自动补全TextBox
转自我本良人 原文 jquery autocomplete实现读取sql数据库自动补全TextBox 项目需要这样子一个功能,其他部门提的意见,只好去实现了哦,搞了好久才弄出来,分享一下. 1.前台页 ...
- gocode+auto-complete搭建emacs的go语言自动补全功能
上篇随笔记录了在emacs中使用go-mode和goflymake搭建了go语言的简单编程环境(推送门),今天来记录一下使用gocode+auto-complete配置emacs中go语言的自动补全功 ...
- autocomplete实现联想输入,自动补全
jQuery.AutoComplete是一个基于jQuery的自动补全插件.借助于jQuery优秀的跨浏览器特性,可以兼容Chrome/IE/Firefox/Opera/Safari等多种浏览器. 特 ...
随机推荐
- 基于ThinkPHP3的微信平台开发_1
微信公众平台是个好东西,具体的就不说了,我直接说技术>_< 下图为目录结构一览: 微信开发 - 文件目录结构 平台功能: 此次开发的平台是面向多微信公众号.微信多公众号主(下面简称号主)的 ...
- dvb标准
一.概念 DVB, 数字视频广播Digital Video Broadcasting的缩写, 是由DVB项目维护的一系列国际承认的数字电视公开标准.(欧标)二.分类DVB系统传输方式有如下几种: 卫星 ...
- view的滑动冲突解决方案
一.常见的滑动冲突场景 1.外部滑动方向和内部滑动方向不一致 2.外部滑动方向和内部滑动方向一致 3.上面两种情况的嵌套 二.滑动冲突处理的原则 场景1的处理原则是:当用户左右滑动时,需要让外部的vi ...
- lua 字符串 正则表达式 转义 特殊字符
string.gsub 函数有三个参数:目标串,模式串,替换串.基本作用是用来查找匹配模式的串,并将使用替换串其替换掉: s = string.gsub("Lua is good" ...
- Python 爬虫4——使用正则表达式筛选内容
之前说过,使用urllib和urllib2,只是为了获取指定URL的html内容,而对内容进行解析和筛选,则需要借助python中的正则表达式来完成. 一.预备知识: 1.正则表达式简述: 什么是正则 ...
- Smart3D系列教程5之 《案例实战演练2——大区域的地形三维重建》
一.前言 Wish3D出品的Smart3D系列教程中,前面一讲说明了小物件的照片三维重建,相信大家对建模的流程有了一定的了解.这次讲解中,我们将演示说明以一组无人机倾斜摄影照片为原始数据,通过Smar ...
- 对Java数组中去除重复项程序分析
我作为一个Java菜鸟,只会用简单的办法来处理这个问题.如果有大神看到,请略过,感激不尽! 所以首先先分析这道题目:数组中重复的数据进行删除,并且要让数组里的数据按原来的顺序排列,中间不能留空. 既然 ...
- Html5选择本地视频音频文件播放
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- C#基础_单例模式
控制某个类型的实例数量-唯一一个 class Program { static void Main(string[] args) { test t1 = test.GetInstance(); tes ...
- Mono 3.2 上跑NUnit测试
NUnit是一款堪与JUnit齐名的开源的回归测试框架,供.net开发人员做单元测试之用,可以从www.nunit.org网站上免费获得,最新版本是2.5.Mono 3.2 源码安装的,在/usr/b ...