$ timeout()没有调用inappbrowser [Ionic]

时间:2017-02-01 02:44:27

标签: javascript angularjs ionic-framework

我正在使用初始屏幕(initial.html),我希望它充当闪屏,然后调用inappbrowser。

但是inappbrowser没有开放。如果我直接放置它是有效的。 没有错误也来了。所需的功能是将启动画面视图重定向到inappbrowser,用户将登录,成功登录后将被重定向到视图。(各个部分正在工作,但是当我把它放在TimeOut函数中时它不起作用) 。

有没有更好的方法来实现此功能。

controller.js

.controller('LoginCtrl', function($scope,$timeout,$rootScope,LoginService, $ionicPopup, $state,$location,$ionicPopup) {
  $timeout(function(){                    
    LoginService.loginUser().success(function(data) {
        console.log(data); 
        $location.path('app/playlists');
    }).error(function(data) {
        var alertPopup = $ionicPopup.alert({
            title: 'Login failed!',
            template: 'Please check your credentials!'
        });
    });    
}, 3000);
})

services.js

angular.module('starter.services', [])
.service('LoginService', function($q,$rootScope,$cordovaInAppBrowser,$http,$state,jwtHelper,$location) {
return {
    loginUser: function() {
       var deferred = $q.defer();
       var promise = deferred.promise;
        console.log("Hi Service"); // IT IS REACHING HERE THEN STUCK
        $cordovaInAppBrowser.open(URL, '_self',options).then(function(event){     
    console.log(event);
     // success
  })

  .catch(function(event) {
     console.log(event);
     // error
  });

 $rootScope.$on('$cordovaInAppBrowser:loadstop', function(e, event){
if(userValid){
deferred.resolve(username);  }
else{
deferred.reject('Auth Failed');
}
});

 //promise created outside
 promise.success = function(fn) {
            promise.then(fn);
            return promise;
        }
        promise.error = function(fn) {
            promise.then(null, fn);
            return promise;
        }
        return promise;
    }
});

1 个答案:

答案 0 :(得分:0)

我删除并重新安装了inappbrowser插件,它运行正常。我为这种困惑道歉