自制基于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 相关文章推荐
可以将word转成html的js代码
Apr 11 Javascript
js实现日期级联效果
Jan 23 Javascript
JavaScript strike方法入门实例(给字符串加上删除线)
Oct 17 Javascript
纯javascript响应式树形菜单效果
Nov 10 Javascript
JavaScript制作简单分页插件
Sep 11 Javascript
Bootstrap面板使用方法
Jan 16 Javascript
weex slider实现滑动底部导航功能
Aug 28 Javascript
微信小程序wx:for和wx:for-item的用法详解
Apr 01 Javascript
vue实现页面滚动到底部刷新
Aug 16 Javascript
微信小程序调用wx.getImageInfo遇到的坑解决
May 31 Javascript
react antd表格中渲染一张或多张图片的实例
Oct 28 Javascript
Vue组件更新数据v-model不生效的解决
Apr 02 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
各种咖啡的英文名子是什么
2021/03/03 新手入门
PHP匿名函数(闭包函数)详解
2019/03/22 PHP
Javascript模块化编程(三)require.js的用法及功能介绍
2013/01/17 Javascript
Node.js中使用事件发射器模式实现事件绑定详解
2014/08/15 Javascript
jquery使用$(element).is()来判断获取的tagName
2014/08/24 Javascript
jQuery实现响应浏览器缩放大小并改变背景颜色
2014/10/31 Javascript
window.onerror()的用法与实例分析
2016/01/27 Javascript
jQuery插件zTree实现的多选树效果示例
2017/03/08 Javascript
Vue.js实现网格列表布局转换方法
2017/08/25 Javascript
React 无状态组件(Stateless Component) 与高阶组件
2018/08/14 Javascript
vue-router懒加载速度缓慢问题及解决方法
2018/11/25 Javascript
教你搭建按需加载的Vue组件库(小结)
2019/07/29 Javascript
layerui代码控制tab选项卡,添加,关闭的实例
2019/09/04 Javascript
vue实现数字动态翻牌的效果(开箱即用)
2019/12/08 Javascript
微信小程序实现上传照片代码实例解析
2020/08/04 Javascript
Python编程对列表中字典元素进行排序的方法详解
2017/05/26 Python
使用Python检测文章抄袭及去重算法原理解析
2019/06/14 Python
python实现广度优先搜索过程解析
2019/10/19 Python
python3实现往mysql中插入datetime类型的数据
2020/03/02 Python
python爬虫构建代理ip池抓取数据库的示例代码
2020/09/22 Python
基于CSS3的CSS 多栏(Multi-column)实现瀑布流源码分享
2014/06/11 HTML / CSS
CSS3属性box-sizing使用指南
2014/12/09 HTML / CSS
用html5绘制折线图的实例代码
2016/03/25 HTML / CSS
苹果中国官方网站:Apple中国
2016/07/22 全球购物
ghd法国官方网站:英国最受欢迎的美发工具品牌
2019/04/18 全球购物
学期自我鉴定范文
2013/10/01 职场文书
大学本科毕业生求职简历的自我评价
2013/10/09 职场文书
导游的职业规划书范文
2013/12/27 职场文书
辅导员评语
2014/05/04 职场文书
2014年小学教师工作自我评价
2014/09/22 职场文书
2014年无财产无子女离婚协议书范本
2014/10/09 职场文书
2014年圣诞节寄语
2014/12/08 职场文书
2015大学党建带团建工作总结
2015/07/23 职场文书
小数乘法教学反思
2016/02/22 职场文书
详解redis在微服务领域的贡献
2021/10/16 Redis
如何使用SQL Server语句创建表
2022/04/12 SQL Server