我目前正在研究spring框架。我在页面abc.jsp上有一个按钮,它向我的控制器发送一个GET请求。控制器在DAO中调用一个方法,并返回一个包含数据的列表并将其转发给def.jsp。有没有办法在单击按钮时直接在abc.jsp上显示数据表。在我的研究中,我发现AJAX是一种方法。我之前没有使用过AJAX,我不知道如何使用它,因为我需要获取一个列表。任何帮助,将不胜感激。我在下面附上了我的代码所需的片段。提前谢谢,
abc.jsp
<form action="abcd" method="get">
<button type="submit" onclick="startSpin()">Items in ABCD</button>
</form>
控制器代码
@Controller
@RequestMapping("application")
public class ApplicationController {
@Autowired
AppDAO AppDAO;
private static final Logger LOGGER = LoggerFactory.getLogger(MasterDataObjectEntityController.class);
@RequestMapping (value="/abcd",method=RequestMethod.GET)
public String getItemsInABCD(ModelMap map, HttpServletRequest req){
LOGGER.info("ApplicationController :: ");
try {
map.addAttribute("ItemsInABCDList", AppDAO.getItemsInABCDList());
} catch (SQLException e) {
LOGGER.error("ApplicationController :: getItemsInABCDList:: SQLException ::"+e.getMessage());
}
return "def"; <-- goes to def.jsp
}
}
def.jsp
<table class="table table-bordered table-striped table-hover"
id="mytable" style="width: 95%;">
<thead>
<tr style="font-weight: bold;">
<td>col 1</td>
<td>col 2</td>
</tr>
</thead>
<tbody>
<c:forEach var="myvar" items="${ItemsInABCDList}">
<tr>
<td>${myvar.itemNumber}</td>
<td>${myvar.itemName}</td>
</tr>
</c:forEach>
</tbody>
</table>
<script type="text/javascript">
var mytable= null;
$(document).ready(function() {
mytable= $('#mytable').dataTable(
{
//columnDefs: [ { orderable: false, targets: [0] }]
columnDefs: [{
targets: "datatable-nosort",
orderable: false
}]
});
$('[data-toggle="tooltip"]').tooltip();
});
</script>
答案 0 :(得分:1)
您需要对代码进行少量更改。如果可行的话。 您可以使用 Javascript 功能通过 POST / GET
来调用Axaj请求使用请求Url调用createAjaxRequest函数,即abcd,并指定您的回叫功能名称,即yourCallbackFuncationName
createAjaxRequest("abcd",yourCallbackFuncationName);
function createAjaxRequest(requestURL,callbackFuncation){
var xmlhttp;
startStopLoader(true);
if (window.XMLHttpRequest){
xmlhttp=new XMLHttpRequest();
} else {
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function(){
if (xmlhttp.readyState==4 ){
if(xmlhttp.status == 200){
try{
callbackFuncation(xmlhttp.responseText);
}catch(e){
}
}
}
}
xmlhttp.open("GET",requestURL,true);
xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
}
function yourCallbackFuncationName(response) {
// you can manupulate your list stored in response variable
// you can generate your tr/td here and put it back in your main
table using innerHTML
}
你需要在你的java文件中使用@ResponseBody并返回你的项目列表。这看起来像下面的代码
@RequestMapping (value="/abcd",method=RequestMethod.GET)
@ResponseBody
public ItemsInABCDListBean getItemsInABCD(ModelMap map, HttpServletRequest req){
LOGGER.info("ApplicationController :: ");
try {
ItemsInABCDListBean ItemsInABCDList = AppDAO.getItemsInABCDList();
} catch (SQLException e) {
LOGGER.error("ApplicationController :: getItemsInABCDList:: SQLException ::"+e.getMessage());
}
return ItemsInABCDList; // returns List you want to show
}
希望这会对你有所帮助。它可能是您的应用程序的通用代码