在这个示例中,我们将使用Ajax和JSON来实现前后端数据的传输,并假设你已经有了一个基本的SSM(Spring MVC + Spring + MyBatis)框架。
后端(Spring MVC Controller):
@Controller
public class DataController {
@RequestMapping(value = "/getData", method = RequestMethod.GET)
@ResponseBody
public Map<String, Object> getData(@RequestParam("param") String param) {
// 示例数据
List<String> dataList = Arrays.asList("data1", "data2", "data3");
Map<String, Object> result = new HashMap<>();
result.put("status", "success");
result.put("data", dataList);
return result;
}
}
前端(HTML + JavaScript):
<!DOCTYPE html>
<html>
<head>
<title>Ajax JSON Example</title>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script>
$(document).ready(function() {
$("#fetchData").click(function() {
$.ajax({
url: '/getData?param=example',
type: 'GET',
dataType: 'json',
success: function(response) {
if(response.status === "success") {
var dataList = response.data;
// 处理dataList,例如显示在页面上
console.log(dataList);
} else {
// 处理错误情况
console.error("Error fetching data");
}
},
error: function(xhr, status, error) {
console.error("An error occurred: " + status + "\nError: " + error);
}
});
});
});
</script>
</head>
<body>
<button id="fetchData">Fetch Data</button>
</body>
</html>
在这个例子中,我们使用jQuery库来简化Ajax请求的编写。当用户点击按钮时,发起一个GET请求到后端的/getData
路径,并期望返回JSON格式的数据。后端Controller处理请求,返回一个包含状态和数据的JSON对象。前端JavaScript通过Ajax成功响应后处理这些数据。