我正在尝试编写一个简单的应用程序,它执行以下操作: 1. 用户输入 2 个参数并单击一个按钮 2. Angular 调用一个返回 JSON 的外部 JAVA Servlet 3. 应用程序将 json 字符串输出到屏幕
但是我有一个问题,因为当我单击按钮时没有任何反应。我相信(由于测试)发生这种情况的原因是由于调用是异步的,因此返回的变量为空。
相关代码:
控制器.js
function myAppController($scope,kdbService) {
$scope.buttonClick = function(){
var dat = kdbService.get($scope.tName,$scope.nRows);
$scope.data = dat;
}
}
服务.js
angular.module('myApp.services', []).factory('kdbService',function ($rootScope,$http){
var server="http://localhost:8080/KdbRouterServlet";
return {
get: function(tname,n){
var dat;
$http.jsonp(server+"?query=krisFunc[`"+tname+";"+n+"]&callback=JSON_CALLBACK").
success(function(data, status, headers, config) {
console.log("1");
console.log(data);
dat=data;
}).
error(function(data, status, headers, config) {
alert("ERROR: Could not get data.");
});
console.log("2");
console.log(dat);
return dat;
}
}
});
索引.html
<!-- Boilerplate-->
<h1>Table Viewer</h1>
<div class="menu" >
<form>
<label for="tName">Table Name</label>
<input id="tName" ng-model="tName"><br>
<label for="nRows">Row Limit</label>
<input id="nRows" ng-model="nRows"><br>
<input type="submit" value="Submit" ng-click="buttonClick()">
</form>
</div>
{{data}}
<!-- Boilerplate-->
当我执行代码并按下按钮时,没有任何反应。但是,如果我查看我的日志,我会看到:
2
undefined
1
Object {x: Array[2], x1: Array[2]}
显然,发生的事情是成功函数在 get 函数返回之后返回。因此放入 $scope.data 的对象是未定义的,但是从 jsonp 调用返回的对象被留下了。
有没有正确的方法可以做到这一点?我看到的大多数教程都将数据分配给成功函数内的 $scope 变量,从而跳过了这个问题。如果可能的话,我希望我的服务是分离的。
任何帮助,将不胜感激。