gpt4 book ai didi

angularjs - 无法访问 Firebase 对象属性。值显示为未定义的 ANGULARFIRE

转载 作者:行者123 更新时间:2023-12-03 08:27:34 29 4
gpt4 key购买 nike

我想为我所做的演示做一个自定义登录,但我遇到了问题。

我使用用户名访问 Firebase 内的引用 url,我得到一个返回的对象。如果我想访问单个属性,我会得到未定义的值,但是如果我在我的 html {{returnedObj.name}} 中添加该值,则会显示该值。

这是为什么?

angular.module('Demo').controller('loginCtrl', ['$scope', '$firebase', '$location',    function($scope, $firebase, $location){
$scope.user = {};
$scope.check = function(){
console.log('https://fabritzio-demo.firebaseio.com/users/' + $scope.user.name);
$scope.returnedObj = $firebase(new Firebase('https://fabritzio-demo.firebaseio.com/usuarios/' + $scope.user.name)).$asObject();
alert($scope.returnedObj.name); // returns undefined value
};

}]);

最佳答案

Firebase 值是异步加载的。当 $scope.returnedObj 触发时,该值尚未加载到 alert 中。

有几种方法可以处理从 Firebase 异步加载的值,例如使用 $loaded 获取 promise :

$scope.returnedObj.$loaded().then(function () {
alert($scope.returnedObj.name);
});

该值显示在模板中是因为 Angular 会监视所有 $scope 变量的变化。当该值被加载时(几毫秒后),它会立即显示出来。

关于angularjs - 无法访问 Firebase 对象属性。值显示为未定义的 ANGULARFIRE,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25450325/

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