Jquery autocomplete 异步加载下拉数据

随记一下自己用到jquery autocomplete时的方法。

首先定义一个文本框

<input type="hidden" id="statId" value="-1"> 
<input type="text" class="form-control grayTips" id="statName" placeholder="请输入站点名称/拼音首字母">
</pre><p><pre name="code" class="javascript">    function onLoadStation() {

		$("#statName").autocomplete({
			source:function(request,response){
				$.ajax({
					type:"POST",
					url:"<%=path%>/jsp/stat.do?action=getStatList",
					dataType : "json",
					cache : false,
					async : false,
					data : {
						"statName" : encodeURI($("#statName").val())
					},
					success : function(json) {
						var data = eval(json);//json数组

						response($.map(data,function(item){
							var name = item.name;
							var id = item.id;
							return {
								label:item.code+'--'+ item.name,//下拉框显示值
								value:item.name,//选中后,填充到下拉框的值
								id:item.id//选中后,填充到id里面的值
							}
						}));
					}
				});
			},
			delay: 500,//延迟500ms便于输入
			select : function(event, ui) {
				$("#statId").val(ui.item.id);
			}
		});
	}
后台action返回Json格式数据,

            //get param异步加载站点下拉列表
            String statName = URLDecoder.decode(request.getParameter("statName") == null ? "" : request.getParameter("statName").trim(), "utf-8");
            JSONArray jsonArray = new JSONArray();
            JSONObject jsonObject = new JSONObject();
            StatService service = new StatService();
            List statList = service.getStatList(statName);
            if (statList != null)
            {
                for (int i = 0; i < statList.size(); i++)
                {
                    StationTable s = (StationTable)statList.get(i);
                    jsonObject.put("id", s.getStatId());
                    jsonObject.put("name", s.getStatName());
                    jsonObject.put("code", s.getStatCode());
                    jsonArray.add(jsonObject);
                }
            }
            PrintWriter pw = null;
            StringBuffer sb = new StringBuffer();
            sb.append(jsonArray.toString());
            try
            {
                response.setContentType("text/html;charset=GBK");
                pw = response.getWriter();
                pw.write(sb.toString());
                pw.close();
            }
            catch (IOException e)
            {
                e.printStackTrace();
            }

效果如图:



  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值