- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是我的代码:
显示.jsp:
<%
JSONArray jsonArray = new JSONArray();
String location = request.getParameter("location");
Class.forName(OracleDriver.class.getName().toString());
Connection connection = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:XE","ram","ram");
PreparedStatement preparedStatement = connection.prepareStatement("select * from job where location = ?");
preparedStatement.setString(1,location);
ResultSet resultSet = preparedStatement.executeQuery();
int index = 0;
if(!resultSet.next()){
jsonArray.add(0, new Job("NA","NA","NA","NA","NA"));
out.println(jsonArray);
}else{
while(resultSet.next()){
index ++;
Job job = new Job(resultSet.getString("title"),resultSet.getString("location"),resultSet.getString("eligibility"),resultSet.getString("position"),resultSet.getString("pdate"));
jsonArray.add(index, job);
}
out.println(jsonArray);
}
%>
包含 Job 对象列表的 jsonArray,我如何在javascript中解析jsonArray
任何想法...
最佳答案
一个建议可能是将隐藏的 dom 元素附加到 JavaScript 变量,例如 p 或隐藏输入。
然后,将内部 html 设置为您的 json 数组
<p id="myJsonArray" style="display:none;"> <%= jsonArray %> </p>
最后,附加一些事件,以触发 javascript 函数来读取该元素的内部 html
...如果您希望自动执行,可能是一个定时间隔或其他内容来检查该元素是否发生更改.
老实说,我会忘记所有这些,只编写一个 Web 服务(使用 Jersey 或其他东西),然后创建一个 ajax 调用来获取你想要的:)但是,这是我的意见。
如果您需要任何进一步的想法,请告诉我!
Here's some working code. I would still like to emphasise that this is likely not the best approach. Having this much code mixed within a html page is very hard to maintain, and is not readable. I found this linked to on another StackOverflow post. It's worth a read. https://netbeans.org/kb/docs/javaee/ecommerce/design.html#architecture
The StackOverflow post: JSF vs Facelets vs JSP
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@ page import="java.util.List,java.util.ArrayList,org.json.JSONArray,java.util.Arrays" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>test</title>
<!-- DataTables CSS -->
<link rel="stylesheet" type="text/css" href="//cdn.datatables.net/1.10.3/css/jquery.dataTables.css">
<!-- jQuery -->
<script type="text/javascript" charset="utf8" src="//code.jquery.com/jquery-1.10.2.min.js"></script>
<!-- DataTables -->
<script type="text/javascript" charset="utf8" src="//cdn.datatables.net/1.10.3/js/jquery.dataTables.js"></script>
<script>
$(function(){
//If your data won't change, you could just draw the table immediately after the page loads.
var testTable = $("#dynamicTable").DataTable({
data : JSON.parse($("#hiddenJson").html())
});
//If you're going to be updating data dynamically, you might
$("#refresh").click(function(){
var data = JSON.parse($("#hiddenJson").html());
testTable.clear();
var modifiedData;
for(r in data) {
modifiedData = data[r];
modifiedData[0] += " dynamically added";
modifiedData[1] += " dynamically added";
modifiedData[2] += " dynamically added";
testTable.row.add(modifiedData);
};
testTable.draw();
});
});
</script>
</head>
<body>
<%
JSONArray jsonArray = new JSONArray();
String location = request.getParameter("location");
// Class.forName(OracleDriver.class.getName().toString());
// Connection connection = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:XE","ram","ram");
// PreparedStatement preparedStatement = connection.prepareStatement("select * from job where location = ?");
// preparedStatement.setString(1,location);
// ResultSet resultSet = preparedStatement.executeQuery();
//int index = 0;
//if(!resultSet.next()){
// jsonArray.add(0, new Job("NA","NA","NA","NA","NA"));
// out.println(jsonArray);
//}else{
// while(resultSet.next()){
// index ++;
// Job job = new Job(resultSet.getString("title"),resultSet.getString("location"),resultSet.getString("eligibility"),resultSet.getString("position"),resultSet.getString("pdate"));
// jsonArray.add(index, job);
// }
jsonArray.put(0, ("NA,NA,NA").split(","));
jsonArray.put(1, ("NA2,NA2,NA2").split(","));
jsonArray.put(2, ("NA3,NA3,NA3").split(","));
%>
<p id="hiddenJson" style="display:none;"> <%= jsonArray.toString() %> </p>
<table id="dynamicTable">
<thead>
<th>column 1</th>
<th>column 2</th>
<th>column 3</th>
</thead>
</table>
<button id="refresh"> Update Data </button>
</body>
</html>
关于java - 我如何将 JsonArray 从 jsp 解析为 Javascript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26569907/
是否可以让标准 Java EE servlet 容器将文件解释并呈现为 JSP,即使该文件没有 .jsp 扩展名? 假设我的 WAR 根目录中有一个名为 foo.xyz 的文件。该文件包含一些 jST
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 6年前关闭。 Improve thi
我有几个通用元素(组件),它们会生成一些 html。似乎我的选择是创建一个 taglib,或者只是将该逻辑放入一个 jsp 页面并包含 jsp。 有什么不同?积极与消极? 最佳答案 Taglibs 允
我是 Ejb-JSP 的新手,对它知之甚少。我已经创建了一个 JSP 页面,它调用 Controller Servlet,而 servlet 调用 EJB。结构就像 JSP -> Servlet ->
我想编写一个自定义 JSP 标签,其输出包括其他 JSP 标签,这些标签本身也应该被动态评估。但显然我的一切TagSupport子类写入 pageContext.getOut()无需任何进一步评估,直
我有一个包含页面顶部内容的 JSP,我们称它为 header.jsp。出于性能原因,我想呈现此 JSP 并将其刷新给用户,然后再构建页面的其余部分。 (有关性能优势的解释,请参阅 here。) 我能想
我发现自己在处理一些旧的 JSP,想做一些简单的事情,比如以 dd/mm/yyyy 格式显示今天的日期 好像没那么简单, 到目前为止,我已经导入了 java.util.* 我试过很多东西 String
关于 JSP 标签字符集的简单问题。 mytag很简单。 tag文件位于 WEB-INF/tags .这个文件在 Eclipse 中的字符集是 UTF-8。出于某种原因,UTF-8 符号无法
这让我很吃惊!我的 JSP 中有以下代码。 在我重构 SlideShow 类并公开所有属性并删除 getter/setter 之前,这段代码一直有效。所以在我看来,EL 只适用于 getter 而不
现有的一组 JSP,用英文字段标签、javascript 错误/信息消息、图像“alt”消息等硬编码,需要多语言化。 将这些 JSP 转换为使用标准 Java 多语言功能(资源包、语言环境等)的最佳方
Closed. This question needs to be more focused。它当前不接受答案。 想改善这个问题吗?更新问题,使其仅通过editing this post专注于一个问题
我已经在 Tomcat 6.0 下部署了我们的 War 到 Linux 服务器。在那个 Linux 机器上,我们没有打开浏览器的权限。 是否可以从命令行执行 JSP? 最佳答案 您可以使用其中 wge
有没有人建议为 JSP 设置最佳缓冲区大小?您可以使用以下页面指令在 JSP 中设置缓冲区大小 我的问题如下 我的理解是,您使用的缓冲区大小越小,客户端浏览器的性能就越好。我的假设正确吗?如
我们正在使用 JBoss 7.1.3.Final 和 Java 6。我想将 UTF-8 页面编码应用于我们网站上提供的所有 JSP 页面,因此我将其添加到我们的 web.xml 文件中
学过jsp native,想包含动态文件。我想使用 include 调用动态页面 这段代码 如果我输入 dashboard.jsp?p=about 页面打开“pages/a
在我的 JSP 页面中,我希望链接转发到另一个 JSP 页面。当用户在 home.jsp 上时,我希望他们转到 login.jsp 等。我遇到的问题是无法找到 JSP,除非我将页面放在项目文件夹中(在
我正在尝试在新的grails应用程序中使用index.jsp切换index.gsp。我将默认的index.gsp重命名为not_index.gsp,并添加了index.jsp。现在,我收到以下错误。
是否可以从服务器端 jsf 代码将资源打开到新的浏览器选项卡(如命令按钮的 target="_newtab")? 以下代码在同一选项卡中打开资源: FacesContext.getCurrentIns
我想问一个关于 .jsp 的问题。使用 jsp 语法(例如 )和 XML 语法(例如 ... )有什么不同。使用其中一种语法是否有维护或某种 advs?谢谢。 最佳答案 原始的 语法更加紧凑,但如
JSP 文件是否有行业标准命名约定? 我遇到过来自不同来源的三种约定: 全部小写 (thisismyfile.jsp) 首字母小写的驼峰式大小写 (thisIsMyFile.jsp) 首字母大写的驼峰
我是一名优秀的程序员,十分优秀!