ng-禁用的角度JS来评估获得$http.get的函数


ng-disabled angular js to evaluate a function that gets $http.get

我试图使我的ng-disbaled按钮评估为控制器中的函数,该函数返回来自$http的请求。

我的网页代码

<a class="btn btn-warning"  ng-click="upVote(item,me.email);" ng-disabled="votecheck(item,me.email) != 'canvote'">

控制器

$scope.votecheck = function(item,emailid){
    var email = emailid;
http.post('ajax/voters.php?id='+item.ID+'&email='+email).success(function(data)
{
        if(data === "CanVote")
        {
            return "canvote";
        }
else
{
    return "cant vote";
}
    });
};

我的 PHP echo 可以投票或不能投票,如果超过数据库的 SQL 状态有人请帮助完成这项工作

注意 我的项目 ID 已预加载以前的范围函数

试试这个

$scope.votecheck = function (item, emailid) {
     return $http.post('upload.php').then(function(data) {
         if (data === "CanVote")
             {
                  $scope.returnValue = "canvote";
             }
             else
             {
                  $scope.returnValue = "cant vote";
              }
                  return $scope.returnValue;
              });
};
$scope.votecheck(item, emailid).then(function(data) {
    console.log(data);
})

由于您正在使用 http.post 进行异步调用,因此无法"返回"值本身。

需要根据进入成功回调的数据在作用域上设置一些canVote属性。

所以 html 会像:

<a class="btn btn-warning"  ng-click="upVote(item,me.email);" ng-disabled="!canVote">

您的新函数如下所示:

function voteCheck(item,emailid) {
  var email = emailid;
  http.post('ajax/voters.php?id='+item.ID+'&email='+email).success(function(data) {
    $scope.canVote = (data === 'CanVote');
  });
}
voteCheck(item, emailid);
hi all i was able to solve my problem using traditionall javascript .ajax with this
Thanx y'all    
$scope.votecheck = function(item,emailid){
        var email = emailid;
       var jsonData = $.ajax({
        type: "GET",
              url: 'ajax/voters.php?id='+item.ID+'&email='+email,
                    dataType: 'json',
                    async: false
                }).responseText;
    if(jsonData === "CanVote"){
        return true;
    }
    else{
        return false;
    }   //return "canvote";
    }