自制基于jQuery的智能提示插件一枚


Posted in Javascript onFebruary 18, 2011

目前实现如下功能:

1 最基本需求,根据当前文本框字符取出适配数据
  1.1 支持同一页面多个元素调用本插件
  1.2 必需的参数是url
  1.3 对于连续不断地输入,会把之前的ajax请求全部取消,避免造成服务器无谓的压力(图4)
  1.4 最基本调用$("myel").autoCmpt({url:"url"});
2 空关键词查询开关(emptyRequest),打开则鼠标点在输入框内即出现提示(当下拉列表用),默认为true(图1)
3 支持关联查询,即当前文本框的提示结果可依据页面另一个元素的取值
  3.1 只支持一个关联元素(即父元素),用参数parentID定义,(默认null)
  3.2 在打开了parentID选项的情况下,假如参数定义useParentValue=false(默认),则插件会取其自定义属性进行过滤(关联),否则(true),会取该元素的value属性关联
    3.2.1 鉴于上述情况,在useParentValue属性为假时,该元素必须为调用了本插件的元素,
    3.2.2 当useParentValue属性为真是,该元素必须为表单元素(即必须有value属性),但不必要是智能提示元素
    3.2.3 不定义parentID,则此项无意义
    3.2.4 定义了parentID的情况下,必须parent元素有值,否则也不会出现提示
4 支持缓存最后查询的结果。(页面多个元素调用的情况下,同样会判断最后一次触发提交的元素来确定是否使用缓存)
  4.1  目前只支持了缓存一个元素的一次结果,有时间的话可考虑扩展成每个元素的最后一次查询结果都缓存起来
5 默认效果见图1,包含:
  5.1 每项的文字描述
  5.2 每项的拼音简拼(如果有)
  5.3 每项对应的数据库的主键值(如果有),不可见
6 多列视图,解决大量短信息的排列(比如人名),(图2)
  6.1 用multi=false打开
  6.2 拼音选项不可见
  6.3 主键值不可见,但是仍然存在
  6.4 只有在取出的记录数大于32时才可用(4*8,目前这个值不可配,跟CSS强关联了,假如你更改了CSS,主要指提示框的宽度,那么请自行更改成合适的效果)。
7 数据过多可分页
  8.1 目前不支持配置每页显示数
  8.2 目前不支持往回翻页
  8.3 如果该元素选项为multi=true,会智能判断下一页条目数量,达到数量条件会自动变成多列视图,否则会恢复默认视图(图3)
8 响应的键盘命令有
  ↑ ←:上一条
  ↓ →:下一条
  ESC取消提示
  没有拦截回车事件,会提交表单
9 对后台返回的数据格式有要求,见插件内说明,目前实现四个字段:id,文字,拼音,上级id,哪怕没有值,也要送个空值回来
  9.1 就小项目用用,所以没有做过多扩展,否则可以像google一样,预留相当多的字段,以及用多维数组返回结果,现在这个做普通提示完全够用了,欢迎自己扩展
10 一般网站方案:
  10.1 google采用的是普通的ajax查询,返回一个数组,里面包含了查询条件和查询结果(本插件返回值无查询条件)
  10.2 baidu采用的ajax返回的是script,把结果做为script的参数传进来再自动执行了
  10.3 酷讯采用的是jQuery的jsonp方式,以callback的方式返回结果集(一般我用jsonp的时候是为了跨域,即处理请求的域名和当前页面域名不一致,浏览器会阻止提交)。
  10.4 本插件采用的是第一种方案。如果智能提示源不在本域,可参照百度、酷讯等的方式进行更改
11 下载地址:本地下载

SVN:http://jq-intellisense-autocomplete.googlecode.com/svn/trunk/

注:下载下来的示例项目是一个asp.net网站,需要.net framework3.5支持,发布到iis上即可运行,或用vs2008+打开网站

图一,默认视图

自制基于jQuery的智能提示插件一枚

图二,多列视图

自制基于jQuery的智能提示插件一枚

图三,当图二的情况下继续输入或翻页,结果少于单页时,自动恢复默认视图

自制基于jQuery的智能提示插件一枚

图四,演示连续输入情况下取消之前的ajax请求

自制基于jQuery的智能提示插件一枚

Javascript 相关文章推荐
js textarea自动增高并隐藏滚动条
Dec 16 Javascript
javascript中this做事件参数相关问题解答
Mar 17 Javascript
使用JS CSS去除IE链接虚线框的三种方法
Nov 14 Javascript
JS获取iframe中longdesc属性的方法
Apr 01 Javascript
JavaScript代码实现禁止右键、禁选择、禁粘贴、禁shift、禁ctrl、禁alt
Nov 17 Javascript
jQuery实现移动端滑块拖动选择数字效果
Dec 24 Javascript
javascript中的后退和刷新实现方法
Nov 10 Javascript
jQuery文字轮播特效
Feb 12 Javascript
JS中数组与对象的遍历方法实例小结
Aug 14 Javascript
require.js 加载过程与使用方法介绍
Oct 30 Javascript
一文看懂如何简单实现节流函数和防抖函数
Sep 05 Javascript
简单实现节流函数和防抖函数过程解析
Oct 08 Javascript
jQuery结合Json提交数据到Webservice,并接收从Webservice返回的Json数据
Feb 18 #Javascript
js判断IE6/IE7/FF的代码[XMLHttpRequest]
Feb 16 #Javascript
基于jquery的复制网页内容到WORD的实现代码
Feb 16 #Javascript
Jquery之美中不足小结
Feb 16 #Javascript
jquery的index方法实现tab效果
Feb 16 #Javascript
jQuery ready函数滥用分析
Feb 16 #Javascript
获取css样式表内样式的js函数currentStyle(IE),defaultView(FF)
Feb 14 #Javascript
You might like
php桌面中心(二) 数据库写入
2007/03/11 PHP
android上传图片到PHP的过程详解
2015/08/03 PHP
javascript dom 操作详解 js加强
2009/07/13 Javascript
javascript 动态table添加colspan\rowspan 参数的方法
2009/07/25 Javascript
Document对象内容集合(比较全)
2010/09/06 Javascript
Javascript的一种模块模式
2010/09/08 Javascript
IE6弹出“已终止操作”的解决办法
2010/11/27 Javascript
纯JAVASCRIPT图表动画插件Highcharts Examples
2011/04/16 Javascript
JS画线(实例代码)
2013/11/20 Javascript
js利用数组length属性清空和截短数组的小例子
2014/01/15 Javascript
使用AJAX实现Web页面进度条的实例分享
2016/05/06 Javascript
AngularJs表单验证实例代码解析
2016/11/29 Javascript
vue实现全选和反选功能
2017/08/31 Javascript
基于bootstrop常用类总结(推荐)
2017/09/11 Javascript
JS使用正则表达式找出最长连续子串长度
2017/10/26 Javascript
小程序点赞收藏功能的实现代码示例
2018/09/07 Javascript
Python中的CURL PycURL使用例子
2014/06/01 Python
python通过urllib2获取带有中文参数url内容的方法
2015/03/13 Python
Python Tkinter模块实现时钟功能应用示例
2018/07/23 Python
Python抽象和自定义类定义与用法示例
2018/08/23 Python
基于python实现语音录入识别代码实例
2020/01/17 Python
python 读取二进制 显示图片案例
2020/04/24 Python
移动端rem布局的两种实现方法
2018/01/03 HTML / CSS
用HTML5实现鼠标滚轮事件放大缩小图片的功能
2015/06/25 HTML / CSS
Html5 webRTC简单实现视频调用的示例代码
2020/09/23 HTML / CSS
马来西亚最大的在线隐形眼镜商店:MrLens
2019/03/27 全球购物
西班牙用户之间买卖视频游戏的平台:Wakkap
2020/03/21 全球购物
2013年高中生自我评价
2013/10/23 职场文书
摄影展策划方案
2014/06/02 职场文书
篮球比赛拉拉队口号
2014/06/10 职场文书
大跃进口号
2014/06/16 职场文书
2014年图书管理员工作总结
2014/12/01 职场文书
行政助理岗位职责范本
2015/04/11 职场文书
我的长征观后感
2015/06/09 职场文书
2015年学校管理工作总结
2015/07/20 职场文书
详解python的异常捕获
2022/03/03 Python