0

我正在尝试通过从数据库中检索数据来实现一个简单的 jquery 自动完成功能。但不知何故,不显示带有建议的自动完成下拉菜单。当我有一个硬编码数组时它工作正常。只有 JSP 存在问题。

我的 list.jsp 代码。

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@page import="java.sql.*"%>
<%@page import="java.util.*"%>

<% 
try{      
     String s[]=null;
        ResultSet rs = null;

    Class.forName("oracle.jdbc.driver.OracleDriver"); 
    Connection con =DriverManager.getConnection("jdbc:oracle:thin:@tst:1521:gtst02","tiger","tiger");
    String queryy=("SELECT ID FROM (SELECT DISTINCT NAME FROM GOOG  WHERE NUM LIKE ? ) WHERE ROWNUM<11");
    PreparedStatement st=con.prepareStatement(queryy); 
    String query = (String)request.getParameter("q");
    st.setString(1,query+"%");
    rs = st.executeQuery();
    while (rs.next()) {
        out.print(rs.getString("CONTRACT_NUM")+"\n");
        }       
    rs.close(); 
    st.close(); 
    con.close();

        } 
    catch(Exception e){ 
        e.printStackTrace(); 
    }
 %>

我的html代码:

<html lang="en">
<head>

<meta charset="utf-8" />


<title>jQuery UI Autocomplete - Remote datasource</title>


<link rel="stylesheet"
href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css" />
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
<link rel="stylesheet" href="/resources/demos/style.css" />

<style>
.ui-autocomplete-loading {
background: white url('images/ui-anim_basic_16x16.gif') right center
    no-repeat;
}
</style>
<script>
 $(function() {

     //var availableTags = [ "ActionScript","AppleScript"];
     $( "#tags" ).autocomplete({      
         source: "list.jsp"    
         });
 });
 </script>

</head>

<body>
<div class="ui-widget">  

<label for="tags">Tags: </label>  

<input id="tags" /></div>


 </body>
</html>

当我打

http://localhost:7001/Test/list.jsp&q=206 

它会显示一个弹出窗口,询问我是打开文件还是打开(下载)。当我打开时,它会在记事本中显示带有长空格的值。

请让我知道我哪里出错了?它适用于声明的硬编码值数组。

4

1 回答 1

0

请访问: jQuery API

查看传递字符串的部分。简而言之,jQuery 似乎传递了一个名为“term”而不是“q”的参数,并期望 JSON 结果。

您的数据输出不是 jQuery 接受的格式,请在同一链接中查看选项

数组:数组可用于本地数据。有两种支持的格式:

字符串数组:[ "Choice1", "Choice2" ]

具有标签和值属性的对象数组: [ { label: "Choice1", value: "value1" }, ... ]

自从我使用 JSP 以来已经有很长时间了,但我认为这个链接将帮助你自动编码东西。

JSP中带有JsonArray的Ajax jquery

于 2013-08-16T21:09:53.003 回答