使用jQuery的autocomplete实现数据查询一次,联想自动补全

书接上回,上次说到在jsp页面中,通过监听输入框的数值变化,实时查询数据库,得到返回值使用autocomplete属性自动补全,实现一个联想补全辅助操作,链接:使用jquery的autocomplete属性实现联想补全操作-CSDN博客

但是这种方法对数据库压力太大,这次通过改造,实现了页面初始化时将需要补全的全部信息查出放在页面,页面上的补全操作相当于使用本地数据联想补全,大大减轻了数据库压力。

由于是页面初始化时就将返回值放入域中,首先是后台代码:

@RequestMapping(value = "/init")
    public String init(ModelMap map, HttpServletRequest request, HttpServletResponse response) {
        List<AutoCode> autoList = autoService.getCodeList();

        String exchange = JSON.toJSONString(certificateList);
        certificateList = JSON.parseArray(exchange, CertificateCode.class);
        StringBuilder rtnData = new StringBuilder();
        for (AutoCode auto: autoList ){
            rtnData.append(",{'code':'").append(auto.getCode()).append("','name':'").append(auto.getName()).append("'}");
        }
        String rtn = "["+rtnData.toString().substring(1)+"]";
        map.put("autocomplete",rtn);
        return "rtn/autocomplete";

    }

上述代码中掺杂了些个人业务,重点就在于里面那个for循环,核心思路就是,将返回值做成一个json串返回前端,json串格式都是统一的:{’名称’:‘内容’,‘名称’:‘内容’......},我这里做成了每条数据都是代码+内容,业务根据个人来实现即可。

前端代码:

//引用autocomplete的js文件 ,css文件就不做展示了
<script type="text/javascript" src="<%=request.getContextPath()%>/js/jquery.autocomplete.js" charset="U-8"></script>
    <%
        //EL表达式获取后台传回的需要自动补全的内容
        String autocomplete = (String) request.getAttribute("autocomplete");
    %>
    <script type="text/javascript">

//页面自动补全的核心方法
        $(document).ready(function () {
            var autocomplete = <%=autocomplete%>;
            $("#auto").autocomplete(
                autocomplete,
                {
                    //方法属性在上一版文章中有详解
                    minChars: 1,
                    max:10,
                    width: 300,
                    matchContains: true,
                    autoFill: false,
                    //拼装json中的代码与值
                    formatItem:function(item) {
                        return "["+item.code+"]\""+item.name+"\"";
                    },
                    formatMatch: function(row, i, max) {
                        return row.name+ " " + row.code;
                    },
                    formatResult: function(row) {
                        return row.name;
                    }
                }).result(function(event,data,formatted){
                $("#auto").val("");
                if(data!=null && data!=''){
                    $("#auto").val(data.code);
                }
            });
        });

前端的实现实际上就是一个纯页面操作,后台返回前端的数据可以看做是页面写死的数据,这个autocomplete方法直接拿来使用,例如:

 String autocomplete = (String) request.getAttribute("autocomplete");


将上述代码替换为写死的串:
var autocomplete = [{'zsdm':'01','zsmc':'一元二次方程'},{'zsdm':'012','zsmc':'99A坦克'},{'zsdm':'123','zsmc':'hellword'}];

最终实现效果为:

此时便完成了对初始的,监听输入框内容改变实时查询数据库实现自动补全的改造。后台拿到全部的补全信息放到前端,剩余操作便由前端autocomplete属性自动完成。

相关推荐

  1. Elasticsearch集群-实现自动

    2024-03-20 04:28:02       35 阅读
  2. 自动 select antd react

    2024-03-20 04:28:02       59 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-20 04:28:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-20 04:28:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-03-20 04:28:02       87 阅读
  4. Python语言-面向对象

    2024-03-20 04:28:02       96 阅读

热门阅读

  1. UDF提权

    UDF提权

    2024-03-20 04:28:02      43 阅读
  2. Mongodb使用手册

    2024-03-20 04:28:02       38 阅读
  3. Nginx安装教程

    2024-03-20 04:28:02       46 阅读
  4. 【NC15434】wyh的迷宫

    2024-03-20 04:28:02       50 阅读
  5. LeetCode //C - 239. Sliding Window Maximum

    2024-03-20 04:28:02       39 阅读
  6. 5.1.4、【AI技术新纪元:Spring AI解码】Amazon Bedrock

    2024-03-20 04:28:02       35 阅读
  7. 2024.3.19 ARM

    2024-03-20 04:28:02       46 阅读
  8. LeetCode 2864.最大二进制奇数

    2024-03-20 04:28:02       37 阅读
  9. React理念——Fiber架构的主要原理

    2024-03-20 04:28:02       47 阅读
  10. [Vuex]中state状态

    2024-03-20 04:28:02       38 阅读