我试图使我的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";
}