自制基于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 相关文章推荐
初学JavaScript_03(ExtJs Grid的简单使用)
Oct 02 Javascript
JavaScript 在各个浏览器中执行的耐性
Apr 06 Javascript
javascript 设置文本框中焦点的位置
Nov 20 Javascript
js中将URL中的参数提取出来作为对象的实现代码
Aug 16 Javascript
JavaScript 5 新增 Array 方法实现介绍
Feb 06 Javascript
JQuery-tableDnD 拖拽的基本使用介绍
Jul 04 Javascript
javascript:文字不间断向左移动的实例代码
Aug 08 Javascript
javascript陷阱 一不小心你就中招了(字符运算)
Nov 10 Javascript
js实现商城星星评分的效果
Dec 29 Javascript
集成vue到jquery/bootstrap项目的方法
Feb 10 jQuery
node.js中process进程的概念和child_process子进程模块的使用方法示例
Feb 11 Javascript
vue实现桌面向网页拖动文件的示例代码(可显示图片/音频/视频)
Mar 01 Vue.js
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常用函数汇总
2014/12/17 PHP
解决form中action属性后面?传递参数 获取不到的问题
2017/07/21 PHP
jQuery选中select控件 无法设置selected的解决方法
2010/09/01 Javascript
kmock javascript 单元测试代码
2011/02/06 Javascript
自己写的兼容ie和ff的在线文本编辑器类似ewebeditor
2012/12/12 Javascript
js获取url中"?"后面的字串方法
2014/05/15 Javascript
jQuery中:lt选择器用法实例
2014/12/29 Javascript
JavaScript实现简单图片翻转的方法
2015/04/17 Javascript
JQuery自动触发事件的方法
2015/06/13 Javascript
jquery实现select下拉框美化特效代码分享
2015/08/18 Javascript
jquery if条件语句的写法
2016/05/19 Javascript
jQuery实现删除li节点的方法
2016/12/06 Javascript
Web 开发中Ajax的Session 超时处理方法
2017/01/19 Javascript
12个非常有用的JavaScript技巧
2017/05/17 Javascript
js实现数组和对象的深浅拷贝
2017/09/30 Javascript
Vue 中使用vue2-highcharts实现top功能的示例
2018/03/05 Javascript
layer弹出的iframe层在执行完毕后关闭当前弹出层的方法
2018/08/17 Javascript
vue中使用props传值的方法
2019/05/08 Javascript
javascript设计模式 ? 观察者模式原理与用法实例分析
2020/04/22 Javascript
javascript实现京东登录显示隐藏密码
2020/08/02 Javascript
[44:22]完美世界DOTA2联赛循环赛 FTD vs PXG BO2第一场 11.01
2020/11/02 DOTA
[01:07:46]完美世界DOTA2联赛循环赛 Magma vs IO BO2第二场 11.01
2020/11/02 DOTA
Python上下文管理器和with块详解
2017/09/09 Python
为什么选择python编程语言入门黑客攻防 给你几个理由!
2018/02/02 Python
Python元组常见操作示例
2019/02/19 Python
PyQt5 QListWidget选择多项并返回的实例
2019/06/17 Python
Python enumerate函数遍历数据对象组合过程解析
2019/12/11 Python
pycharm新建Vue项目的方法步骤(图文)
2020/03/04 Python
使用Python实现将多表分批次从数据库导出到Excel
2020/05/15 Python
什么是数组名
2012/05/10 面试题
自我鉴定书面格式
2014/01/13 职场文书
公务员综合考察材料
2014/02/01 职场文书
模具毕业生推荐信
2014/02/15 职场文书
八项规定个人对照检查材料思想汇报
2014/09/25 职场文书
演讲开场白台词大全
2015/05/29 职场文书
河童之夏观后感
2015/06/11 职场文书