使用 AngularJS $http 服务将 Angularjs 连接到 Spring RESTFul 服务
Connecting Angularjs to Spring RESTFul service using AngularJS $http service
这是后端的 Spring Rest 控制器,它只获取列表中的所有学生。我已经测试过了,工作正常。
@RestController
@RequestMapping("a/rest")
public class RestfulController {
@Autowired
private StudentDao studentDao;
@RequestMapping(method = RequestMethod.GET)
public ResponseEntity<List<Student>> index() {
ResponseEntity<List<Student>> studList = new ResponseEntity<List<Student>>( studentDao.getAll(), HttpStatus.OK);
return studList;
}
}
这就是我想要做的,我希望学生列表显示在定义了 id(id="displayData") 的段落中
我创建了加载函数 showData() 的按钮
然后我尝试实现 Angularjs 的 $http 服务以这种方式连接到后端
<body>
<input type="button" value="Get Data" onclick="showData()" />
<p id="displayData" />
</body>
<script type="text/javascript">
function showData() {
$http({
method: 'GET',
url: 'a/rest'
}).then(function (response) {
$('#displayData').html(JSON.stringify(response));
});
}
</script>
我需要帮助..!!问题出在前端。我怎样才能实现工作文件的 $http 服务?
试试这个
$('#displayData').html(JSON.stringify(response.data));
服务器端return数据是JSON字符串?
$http 响应将包含
属性。 $http response.data 包含实际 json 数据。它不像 jquery($.ajax()
) 那样工作。
您需要 bootstrap 您的 angular 应用程序才能使用 $http
服务。
以下是满足您需要的最小示例。
<!DOCTYPE html>
<html>
<head>
<script src="https://code.jquery.com/jquery-1.12.4.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.7/angular.min.js"></script>
</head>
<body ng-app="studApp" ng-controller="StudController">
<input type="button" value="Get Data" ng-click="showData()" />
<p id="displayData" />
<script type="text/javascript">
angular.module('studApp', [])
.controller('StudController', function($http, $scope) {
$scope.showData = function() {
$http({
method : 'GET',
url : 'a/rest'
}).then(function(response) {
$('#displayData').html(JSON.stringify(response.data));
});
}
});
</script>
</body>
</html>
这是后端的 Spring Rest 控制器,它只获取列表中的所有学生。我已经测试过了,工作正常。
@RestController
@RequestMapping("a/rest")
public class RestfulController {
@Autowired
private StudentDao studentDao;
@RequestMapping(method = RequestMethod.GET)
public ResponseEntity<List<Student>> index() {
ResponseEntity<List<Student>> studList = new ResponseEntity<List<Student>>( studentDao.getAll(), HttpStatus.OK);
return studList;
}
}
这就是我想要做的,我希望学生列表显示在定义了 id(id="displayData") 的段落中
我创建了加载函数 showData() 的按钮
然后我尝试实现 Angularjs 的 $http 服务以这种方式连接到后端
<body>
<input type="button" value="Get Data" onclick="showData()" />
<p id="displayData" />
</body>
<script type="text/javascript">
function showData() {
$http({
method: 'GET',
url: 'a/rest'
}).then(function (response) {
$('#displayData').html(JSON.stringify(response));
});
}
</script>
我需要帮助..!!问题出在前端。我怎样才能实现工作文件的 $http 服务?
试试这个
$('#displayData').html(JSON.stringify(response.data));
服务器端return数据是JSON字符串?
$http 响应将包含
属性。 $http response.data 包含实际 json 数据。它不像 jquery($.ajax()
) 那样工作。
您需要 bootstrap 您的 angular 应用程序才能使用 $http
服务。
以下是满足您需要的最小示例。
<!DOCTYPE html>
<html>
<head>
<script src="https://code.jquery.com/jquery-1.12.4.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.7/angular.min.js"></script>
</head>
<body ng-app="studApp" ng-controller="StudController">
<input type="button" value="Get Data" ng-click="showData()" />
<p id="displayData" />
<script type="text/javascript">
angular.module('studApp', [])
.controller('StudController', function($http, $scope) {
$scope.showData = function() {
$http({
method : 'GET',
url : 'a/rest'
}).then(function(response) {
$('#displayData').html(JSON.stringify(response.data));
});
}
});
</script>
</body>
</html>