我正在开发一个应用程序,登录后应该将用户从登录页面重定向到主页,我正在通过服务器上的API文件(在这一刻是本地主机)使用http.post
方法进行登录,如果登录是正确的服务器返回字符串“T”然后在我的应用程序我控制,如果字符串等于“T”,如果它是等于应用程序应该重定向用户到主页。如何在离子状态下使用state.go?
我只有一个问题,这是正确使用的功能state.go();
,因为我没有看到在控制台中的任何错误,但页面不会改变,但网址(我测试ionic serve
)改变确切的方式。
这是我的代码:
APP.JS:
angular.module('starter', ['ionic', 'ui.router'])
.run(function($ionicPlatform) {
$ionicPlatform.ready(function() {
if (window.cordova && window.cordova.plugins.Keyboard) {
cordova.plugins.Keyboard.hideKeyboardAccessoryBar(true);
cordova.plugins.Keyboard.disableScroll(true);
}
if (window.StatusBar) {
StatusBar.styleDefault();
}
});
})
.config(['$stateProvider', '$urlRouterProvider', function($stateProvider, $urlRouterProvider) {
$stateProvider
.state('login', {
url: '/',
//abstract : true, // Because your are have child-states under de 'splash' state, you should set it abstract : true;
templateUrl: '/login.html',
controller: "LoginCtrl"
})
.state('main', {
url: "main.html",
templateUrl: "/main.html",
})
}])
.controller('LoginCtrl', function($scope, $http, $state, $ionicHistory) {
$scope.data = {};
$scope.data.funzione = "login";
$scope.submit = function(){
//console.clear();
console.log("Dentro funzione");
console.log($scope.data.funzione);
var link = 'http://localhost/<path>/api.php';
$http.post(link, {mail : $scope.data.mail}, {pwd : $scope.data.pwd}, {funzione : $scope.data.funzione})
.then(function (res){
console.log("Dentro http.post");
$scope.response = res.data;
console.log($scope.response);
if ($scope.response != "F"){
console.log("Dentro if");
$state.go('main');
} else {
console.log("Dentro else");
}
});
};
});
THIS IS MY文件夹:(WWW)
,这是URL后STATE.GO():
http://localhost:8100/login.html#/main.html
但它应该是:
http://localhost:8100/main.html
angular自动分析对json的响应。所以发送'T'或'F'不合乎情理。发送一些json对象,然后在客户端读取响应。你的控制台必须打印'Dentro else'。 –
是的,但用“!='F'”总是为真(是做state.go的测试)@ atulquest93 – Edoardo
你在哪里将maincontroller注入主状态配置部分? –