自制基于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图表动画插件Highcharts Examples
Apr 16 Javascript
JS实现div居中示例
Apr 17 Javascript
jquery实现图片上传之前预览的方法
Jul 11 Javascript
js如何实现点击标签文字,文字在文本框出现
Aug 05 Javascript
JavaScript中的ParseInt("08")和“09”返回0的原因分析及解决办法
May 19 Javascript
那些精彩的JavaScript代码片段
Jan 12 Javascript
微信小程序开发入门基础教程
Apr 19 Javascript
详解基于webpack搭建react运行环境
Jun 01 Javascript
解决vue router使用 history 模式刷新后404问题
Jul 19 Javascript
vue实现样式之间的切换及vue动态样式的实现方法
Dec 19 Javascript
JavaScript经典案例之简易计算器
Aug 24 Javascript
Vue实现简单计算器
Jan 20 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
重置版战役片段
2020/04/09 魔兽争霸
PHP中的CMS的涵义
2007/03/11 PHP
PHP 操作文件的一些FAQ总结
2009/02/12 PHP
PHP中子类重载父类的方法【parent::方法名】
2016/05/06 PHP
PHP的中使用非缓冲模式查询数据库的方法
2017/02/05 PHP
js post方式传递提交的实现代码
2010/05/31 Javascript
javascript通过获取html标签属性class实现多选项卡的方法
2015/07/27 Javascript
JS实现点击按钮控制Div变宽、增高及调整背景色的方法
2015/08/05 Javascript
Jquery全选与反选点击执行一次的解决方案
2015/08/14 Javascript
基于javascript编写简单日历
2016/05/02 Javascript
jQuery实现下拉框多选 jquery-multiselect 的实例代码
2016/07/14 Javascript
jquery自定义插件结合baiduTemplate.js实现异步刷新(附源码)
2016/12/22 Javascript
详解AngularJS ng-class样式切换
2017/06/27 Javascript
Vue 中使用 CSS Modules优雅方法
2018/04/09 Javascript
jQuery发请求传输中文参数乱码问题的解决方案
2018/05/22 jQuery
Vue监听数据渲染DOM完以后执行某个函数详解
2018/09/11 Javascript
详解ES6中的 Set Map 数据结构学习总结
2018/11/06 Javascript
vue模块拖拽实现示例代码
2019/03/09 Javascript
vue addRoutes路由动态加载操作
2020/08/04 Javascript
浅谈vue项目,访问路径#号的问题
2020/08/14 Javascript
使用python3调用wxpy模块监控linux日志并定时发送消息给群组或好友
2019/06/05 Python
Django打印出在数据库中执行的语句问题
2019/07/25 Python
python基础 range的用法解析
2019/08/23 Python
python新式类和经典类的区别实例分析
2020/03/23 Python
Python collections模块的使用方法
2020/10/09 Python
pycharm2020.1.2永久破解激活教程,实测有效
2020/10/29 Python
Pycharm 解决自动格式化冲突的设置操作
2021/01/15 Python
CSS3按钮鼠标悬浮实现光圈效果源码
2016/09/11 HTML / CSS
公司领导推荐信
2013/11/12 职场文书
物业工作计划书
2014/01/10 职场文书
党员组织关系介绍信
2014/02/13 职场文书
公务员个人考察材料
2014/12/23 职场文书
校园环境卫生倡议书
2015/04/29 职场文书
副校长2015年教育教学工作总结
2015/07/27 职场文书
导游词之山东红叶谷
2019/10/31 职场文书
如何使用Python实现一个简易的ORM模型
2021/05/12 Python