gpt4 book ai didi

javascript - ngInit 不异步工作(使用 $q promise)

转载 作者:行者123 更新时间:2023-11-30 17:48:25 25 4
gpt4 key购买 nike

编辑:Plunker 正在工作,实际代码不是: http://plnkr.co/edit/5oVWGCVeuTwTARhZDVMl?p=preview

该服务包含典型的 getter\setter 内容,除此之外,它运行良好,所以我没有发布它的代码以避免 TLDR。

TLDR 版本:尝试将使用 AJAX 获取的值 ng-init 到文本区域的 ngModel 中,请求解析为正确的值,但文本区域仍然为空。

父 Controller 函数(与服务对话):

$scope.model.getRandomStatus = function(){
var deffered = $q.defer();
var cid = authService.getCompanyId();

var suggestions = companyService.getStatusSuggestions(cid);
if(suggestions && suggestions.length > 0){
deffered.resolve(suggestions[Math.floor(Math.random(suggestions.length) + 1)].message);
return deffered.promise;//we already have a status text, great!
}

//no status, we'll have to load the status choices from the API
companyService.loadStatusSuggestions(cid).then(function(data){
companyService.setStatusSuggestions(cid, data.data);
var result = data.data[Math.floor(Math.random(data.data.length) + 1)];
deffered.resolve(result.message);
},
function(data){
_root.inProgress = false;
deffered.resolve('');
//failed to fetch suggestions, will try again the next time the compnay data is reuqired
});
return deffered.promise;
}

子 Controller :

.controller('shareCtrl', function($scope){
$scope.layout.toggleStatusSuggestion = function(){
$scope.model.getRandomStatus().then(function(data){
console.log(data);//logs out the correct text
//$scope.model.formData.shareStatus = data;//also tried this, no luck
return data.message;
});
$scope.model.formData.shareStatus = $scope.layout.toggleStatusSuggestion();//Newly edited
}
});

HTML:

<div class="shareContainer" data-ng-controller="shareCtrl">
<textarea class="textAreaExtend" name="shareStatus" data-ng-model="model.formData.shareStatus" data-ng-init="model.formData.shareStatus = layout.toggleStatusSuggestion()" cols="4"></textarea>
</div>

最佳答案

我相信你想要的是:

$scope.model.getRandomStatus().then(function(data){            
$scope.model.formData.shareStatus = data.message;

});

then 中返回一些东西不会从包装它的函数中返回任何东西,因此什么也不做

关于javascript - ngInit 不异步工作(使用 $q promise),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19611222/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com