Combogrid 是一个jQuery插件用于为输入框添加高级自完成功能(auto-complete)。当用户输入的时候,会在输入框的下方面动态显示一个拥有分页功能 的表格(Grid)控件。 通过Ajax请求,然后结果以JSON(或JSONP:用于跨域请求)的数据类型返回。这个插件拥有许多选项可以配置比如:设置交替行的颜色,自动选择相匹配的查询结果, 设置当输入到第几个字符号才激活表格。此外还支持键盘操作。

  涉及到的相关js和css:

  1、jquery-ui-1.10.1.custom.css

  2、jquery-ui-1.10.1.custom.min.js

  3、jquery.ui.combogrid.css

  4、jquery.ui.combogrid.js

前台页面中代码:

  

  1. <script>
  2. $(document).ready(function(){
  3. $( "#project" ).combogrid({
  4. url: '/per/getTeacherList',
  5. debug:true,
  6. colModel: [{'columnName':'person_id','width':'10','label':'person_id'}, {'columnName':'person_name','width':'60','label':'person_name'},{'columnName':'org_name','width':'30','label':'org_name'}],
  7. select: function( event, ui ) {
  8. $( "#project" ).val( ui.item.person_name );
  9. return false;
  10. }
  11. });
  12. });
  13. </script>
  1. <div>
  2.   <div style="float:left"><input size="30" id="project"/></div><br/> <br/>
  3.   <div id="switcher" style="float:right"></div>
  4. </div>

jfinal中getTeacherList方法的代码示例:

  1. public void getTeacherList(){
  2. //学校ID
  3. int bureau_id = 1;
  4. int page = getParaToInt("page");
  5. //每页显示行数
  6. int limit = getParaToInt("rows");
  7.           //查询条件
  8. String searchTerm = getPara("searchTerm");
  9. if(searchTerm==""){
  10. searchTerm = "%";
  11. } else {
  12. searchTerm = "%" + searchTerm + "%";
  13. }
  14. List<Record> person_list = Person.dao.getTeacherList(bureau_id,searchTerm);
  15. //总条数
  16. int count = person_list.size();
  17. //总页数
  18. int total_pages = 0;
  19. if(count > 0) {
  20. if(count%limit == 0){
  21. total_pages = count/limit;
  22. }else{
  23. total_pages = count/limit + 1;
  24. }
  25. }else{
  26. total_pages = 1;
  27. }
  28. if(page > total_pages) {
  29. page = total_pages;
  30. }
  31. //当前页起始行号
  32. int start = limit * page - limit;
  33. List<Record> list = null;
  34.      //查询数据库
  35. if(total_pages != 0) {
  36. list = Person.dao.getTeacherList(bureau_id,searchTerm, start, limit);
  37. } else {
  38. list = Person.dao.getTeacherList(bureau_id,searchTerm);
  39. }
  40. Map<String,Object> map = new HashMap<String, Object>();
  41. map.put("page", page);
  42. map.put("total", total_pages);
  43. map.put("records", count);
  44. List<Object> list2 = new ArrayList<>();
  45. for (int i = 0; i < list.size(); i++) {
  46. Map<String, Object> map2 = new HashMap<String, Object>();
  47. map2.put("person_id", list.get(i).get("PERSON_ID"));
  48. map2.put("person_name", list.get(i).get("PERSON_NAME"));
  49. map2.put("org_name", list.get(i).get("ORG_NAME"));
  50. list2.add(map2);
  51. }
  52. map.put("rows", list2);
  53. renderJson(JSON.toJSONString(map));
  54.  
  55. }

最终返回给前台的JSON格式为:

{"page":1,"records":2,"rows":[{"org_name":"语文组","person_id":20,"person_name":"张三"},{"org_name":"语文组","person_id":21,"person_name":"李四"}],"total":1}

这样自动完成就实现了。

  

JQuery输入自动完成的更多相关文章

  1. jquery 实现邮箱输入自动提示功能:(二)

    上篇文章写到了一个不错的jquery实现邮箱输入自动提示功能,发现还有一个不错的自动提示插件: 先展示结果如图: html代码: <center> <h1>输入邮箱试试!< ...

  2. jquery 实现邮箱输入自动提示功能:(一)

    记得去年做某个项目的时候,用到了邮箱输入自动提示功能,于是网上搜了一下,发现了这个写得不错,现在回想起来,转载一下,方便查阅. 邮箱的广泛使用得益于它的免费,因此很多网站在注册的时候都会直接使用邮箱作 ...

  3. jQuery实现用户输入自动完成功能

    jQuery实现用户输入自动完成功能 利用jQuery UI中Auto-complete插件实现输入自动完成功能,大家在使用诸如淘宝.京东等电商平台搜索商品时,往往只要输入商品的一些特殊字符,就可以显 ...

  4. 30+最佳Ajax jQuery的自动完成插件的例子

    在这篇文章中,我们将介绍35个jQuery AJAX的自动完成提示例子. jQuery 的自动完成功能,使用户快速找到并选择一定的价值.每个人都想要快速和即时搜索输入栏位,因为这个原因,许 流行的搜索 ...

  5. GBin1插件推荐之马可波罗(Marco Polo),jQuery的自动补齐插件 - Autocomplete Plugin

    让我们Google一下"jQuery autocomplete plugin"(jquery自动补齐插件).在过去的4年中,我已经Google了很多次这个组合了.然而结果并没有变化 ...

  6. 如何在myeclipse中实现jquery的自动提示功能

    在web开发过程中,myeclipse中jsp可以实现自动提示功能,但是jquery代码却无法实现自动提示,需要自己一个个手动去输入,效率过低,怎么办? 工具/原料   jquery 1.8.3.js ...

  7. jQuery AutoComplete 自动补全

    jQuery.AutoComplete是一个基于jQuery的自动补全插件.借助于jQuery优秀的跨浏览器特性,可以兼容Chrome/IE/Firefox/Opera/Safari等多种浏览器. 特 ...

  8. jquery背景自动切换特效

    查看效果网址:http://keleyi.com/a/bjad/4kwkql05.htm 本特效的jquery版本只支持1.9.0以下. 代码如下: <!DOCTYPE html PUBLIC ...

  9. 在eclipse-jee-juno中配置Aptana对jQuery代码自动提示

    主要问题 在Aptana的Web Project中打开js文件有JavaScript的自动提示,但是在JavaEE项目中却没有. 版本 eclipse-jee-juno,即Eclipse 4.2的Ja ...

随机推荐

  1. Atitit.软件开发的几大规则,法则,与原则。。。attilax总结

    Atitit.软件开发的几大规则,法则,与原则... 1. 设计模式六大原则 2 1.1. 设计模式六大原则(1):单一职责原则 2 1.2. 设计模式六大原则(2):里氏替换原则 2 1.3. 设计 ...

  2. atitit.浏览器插件解决方案----ftp插件 attilax 总结

    atitit.浏览器插件解决方案----ftp插件  attilax 总结 1. 界面概览  D:云盘同步文件夹p5p5f tp.demo.html1 2. 初始化1 3. 事实调用2 4. 参考2 ...

  3. JS高程3:Ajax与Comet-XMLHttpRequest对象

    XHR 的用法 XHR对象,即XMLHttpRequest对象,下面看看他常见的属性和方法. open()方法 它接受 3 个参数:要发送的请求的类型("get". "p ...

  4. 李洪强和你一起学习前端之(4)HTML5介绍

    1.1认识HTML5 html的版本: html4 Xhtml1.0 目前: html5是最高的版本 再怎么变化,无非是多了一些标签而已,但是不单单是提供了一些标签 比如: 开发网页游戏 我们可以开发 ...

  5. vim编码设置

    转载于:http://www.cnblogs.com/freewater/archive/2011/08/26/2154602.html vim 编码方式的设置和所有的流行文本编辑器一样,Vim 可以 ...

  6. www--摘录图解TCP/IP

    万维网,www,world wide web,也称web.将互联网中的信息以超文本的形式展现的系统.可以显示www信息的客户端软件叫做web浏览器. www内容 www定义了3个重要的概念,它们分别是 ...

  7. Nginx + PHP-FPM + MySQL + phpMyAdmin on Ubuntu (aliyun)

    今天抽空在阿里云上部署安装了PHP的环境 主要有nginx, php5 php-fpm mysql phpmyadmin 本文来源于:http://www.lonelycoder.be/nginx-p ...

  8. CentOS装JDK1.8

    1.下载jdk1.8:http://download.csdn.net/download/yichen01010/10017267 直接使用liunx下默认安装的浏览器 下载 2.卸载系统自带的jdk ...

  9. tree 命令使用技巧

    一.简介 tree命令可以以目录树的形式显示指定(默认显示这个文件系统)目录的所有文件夹和文件 二.使用 显示一个目录 $ tree folder Tips:如果文件夹有中文,则会显示一串转移字符,使 ...

  10. xml传输过程中中文乱码

    ------------------------------------------request:----------------------------------------------- pu ...