使用AngularJS $ http服务

时间:2016-07-06 08:44:37

标签: angularjs spring-restcontroller

这是后端的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 =&#34; displayData&#34;)

我创建了一个加载函数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服务?

2 个答案:

答案 0 :(得分:0)

试试这个

$(&#39;#displayData&#39)。HTML(JSON.stringify(response.data));

服务器端返回数据是JSON字符串吗?

答案 1 :(得分:0)

$ http响应将包含

$http response json

性质。 $ http response.data包含实际的json数据。它不像jquery($.ajax())那样工作。 您需要先引导角度应用程序,然后才能使用$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>
相关问题