我正在尝试通过从数据库中检索数据来实现一个简单的 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
它会显示一个弹出窗口,询问我是打开文件还是打开(下载)。当我打开时,它会在记事本中显示带有长空格的值。
请让我知道我哪里出错了?它适用于声明的硬编码值数组。