autocomplete 实现的input输入框智能提示

jquery.autocomplete 实现的input输入框智能提示


jquery+ajax+input输入框
jquery 的autocomplete插件

jquery 框架

//导入脚本文件
<link rel="stylesheet" href="/js/jquery-ui.css">
<script type="text/javascript" src="/js/jquery.min.js" ></script>
<script src="/js/jquery-ui.js"></script>

javaScript代码

<div class="col-sm-10">
     <input type="text" autocomplete="off" name="astUids" class="form-control" id="devicesUid" th:value="${repair.astUids}" placeholder="请输入识别码" />
     <div id="auto_div"></div>
</div>
//javascript脚本
<script type="text/javascript">
    $(document).ready(function () {
        $( "#devicesUid" ).autocomplete({
            max: 5,
            minChars: 1,
            matchContains: true,
            minLength: 2,
            width: $("#devicesUid").width()+1,
            matchContains: true,
            source: function( request, response ) {
             // response是一个函数,在你自行处理并获取数据后,将JSON数据交给该函数处理,以便于autocomplete根据数据显示列表
                $.ajax( {
                    url: "/console/oamRepair/inputQuery",
                    dataType: "json",
                    data: {
                        term: request.term      // request对象只有一个term属性,对应用户输入的文本
                    },
                    success: function( data ) {
                        response( $.map( data, function( item ) {
                            return {
                                label: item.label
                                //value: item.value
                            }
                        }));
                    }

                });
            },
            select: function( event, ui ) {
                console.log( "Selected: " + ui.item.value + " aka " + ui.item.label );
            }
        } );
    });
</script>

java 后台代码

  • 接收前端的查询参数,然后以JSON格式返回数据到页面
   @RequestMapping(value = "/inputQuery", method = {RequestMethod.GET})
    public void inputQuery(HttpServletRequest req, HttpServletResponse response) {
        // 查询的参数名称默认为term
        String termValue = req.getParameter("term");
        List<String> codeLists = ....;

        JSONArray devsArray = new JSONArray();
        if(codeLists .size()>0) {
            for (String ac : codeLists ) {
                JSONObject obj = new JSONObject();
                String deviceFullName= getFullCode(ac);
                if(deviceFullName!= null){
                    obj.put("label", deviceFullName);
                    obj.put("value", ac);
                    devsArray.add(obj);
                }
            }
        }
        response.setContentType("application/json;charset=utf-8");
        PrintWriter out =null;
        try {
            out = response.getWriter();
            out.print(devsArray.toJSONString());
            out.flush();
            out.close();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if(out != null){
                out.close();
            }
        }
    }
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值