ionic:错误:updateUserDetails 未定义
2016-06-24
1429
上次升级后,我尝试启动我的应用程序,但在使用过程中出现许多错误。
这是我更新项目后出现的错误之一(登录时,我在几个不同的函数中有许多未定义的错误):
Error: updateUserDetails is not defined
$scope.register/<@http://localhost:8100/js/controls/loginCntrls.js:126:21
processQueue@http://localhost:8100/lib/ionic/js/ionic.bundle.js:27879:28
scheduleProcessQueue/<@http://localhost:8100/lib/ionic/js/ionic.bundle.js:27895:27
$RootScopeProvider/this.$get</Scope.prototype.$eval@http://localhost:8100/lib/ionic/js/ionic.bundle.js:29158:16
$RootScopeProvider/this.$get</Scope.prototype.$digest@http://localhost:8100/lib/ionic/js/ionic.bundle.js:28969:15
$RootScopeProvider/this.$get</Scope.prototype.$apply@http://localhost:8100/lib/ionic/js/ionic.bundle.js:29263:13
done@http://localhost:8100/lib/ionic/js/ionic.bundle.js:23676:36
completeRequest@http://localhost:8100/lib/ionic/js/ionic.bundle.js:23848:7
requestLoaded@http://localhost:8100/lib/ionic/js/ionic.bundle.js:23789:9
此外,当我尝试使用 Facebook 登录时:
ionic.bundle.js:26794 ReferenceError: facebookConnectPlugin is not defined
at Object.login (ng-cordova.js:2190)
at Object.login (facebookService.js:35)
at Scope.$scope.fbLogin (loginCntrls.js:34)
at fn (eval at compile (ionic.bundle.js:27638), <anonymous>:4:290)
at ionic.bundle.js:65427
at Scope.$eval (ionic.bundle.js:30395)
at Scope.$apply (ionic.bundle.js:30495)
at HTMLButtonElement.<anonymous> (ionic.bundle.js:65426)
at defaultHandlerWrapper (ionic.bundle.js:16787)
at HTMLButtonElement.eventHandler (ionic.bundle.js:16775)
这是
updateUserDetails
页面:
angular.module('starter.controllers',[])
.controller('loginCtrl', function($scope, $rootScope, $state, $fbHelper, $ionicLoading, $uiHelper, $api, $ionicHistory, $parsePush) {
$scope.user = {
email: "",
password: ""
};
function handleInputError(emailVal, passwordVal){
var errorMsg = '';
if(!emailVal){
errorMsg = 'Please insert a valid email address';
} else if(!passwordVal) {
errorMsg = 'Please insert your password';
}
if(errorMsg) {
$uiHelper.popError("", errorMsg, function(){});
}
}
function goToFeed(){
$state.go('app.feeds.latest', {type: "getLatestQuestions", reload: true});
}
...
})
.controller('registerCtrl', function ($scope, $rootScope, $state, $ionicLoading, $uiHelper, $api, $ionicHistory, $parsePush) {
console.log("init registerCtrl");
$scope.user = {
email: "",
nickname: "",
password: "",
verify: "",
gender: "m"
};
$scope.register = function($event){
$event.target.blur();
var emailVal = $scope.user.email,
nicknameVal = $scope.user.nickname,
passwordVal = $scope.user.password,
verifyVal = $scope.user.verify,
genderVal = $scope.user.gender;
if(!emailVal || !passwordVal || !nicknameVal || !verifyVal || !genderVal || passwordVal!= verifyVal ){
handleInputError(passwordVal, verifyVal);
return;
}
$ionicLoading.show();
$api.register(emailVal, nicknameVal, passwordVal, genderVal).then(function(data){
if(data && data.error){
$uiHelper.popError("", data.error, function(){});
} else if(data && data._id){
updateUserDetails(data.user); //ERROR IS HERE
$ionicHistory.nextViewOptions({disableBack: true});
$parsePush.initParseNotifications();
}
});
}
});
2个回答
看来您正在 registerCtrl 中调用此行
updateUserDetails(data.user); //Error in this line
。该函数看起来像是在您的 loginCtrl 函数中定义的(我不能确定,因为您在示例中省略了相当一部分代码)。如果您尝试从多个控制器调用此函数,则应考虑在服务中定义它,并将该服务注入需要它的控制器中。
类似这样:
.factory('User', function($rootScope){
return {
updateUserDetails: function(data){
$rootScope.$broadcast('user:updated',{userId : data._id, userPicture: data.picture, userName: data.name, gender: data.gender});
}
}
您需要确保在服务中引用了用户,但希望这可以帮助您入门。
Matt M
2016-06-24
尝试一下:
var updateUserDetails = function(data){
$rootScope.$broadcast('user:updated',{
userId : data._id,
userPicture: data.picture,
userName: data.name,
gender: data.gender
});
}
updateUserDetails(data.user);
Ozan Gunceler
2016-06-24