72

phpファイルに投稿を送信して簡単な認証サービスを作成しようとしています。成功したときにホームページを部分的にロードする必要がありますng-view

これは私が試したものです:

function loginCtrl($scope, $http, $location){
    $http.post(url,data).success(function(data){
        $location.path('/home');
    });
}

URLは変更されますがng-view、更新されません。手動でページを更新すると更新されます。

(ルートはで適切に構成されています$routeProvider。コールバックとしてではなくスタンドアロン関数を使用してこれをリダイレクトすることをテストしましたが、機能します)

また、関数として定義$location.path('/home')してから、コールバックでそれを呼び出しても機能しません。

私はいくつかの調査を行い、別のサードパーティのプラグインを使用しているときにこれが発生することを示すいくつかの記事を見つけました、私はangular.jsのみをロードしています

いくつかの研究資料への洞察や指針は素晴らしいでしょう

4

6 に答える 6

83

これがこの記事のchangeLocationの例ですhttp://www.yearofmoo.com/2012/10/more-angularjs-magic-to-supercharge-your-webapp.html#apply-digest-and-phase

//be sure to inject $scope and $location
var changeLocation = function(url, forceReload) {
  $scope = $scope || angular.element(document).scope();
  if(forceReload || $scope.$$phase) {
    window.location = url;
  }
  else {
    //only use this if you want to replace the history stack
    //$location.path(url).replace();

    //this this if you want to change the URL and add it to the history stack
    $location.path(url);
    $scope.$apply();
  }
};
于 2013-01-17T20:42:01.127 に答える
14

公式ガイドには簡単な答えがあります:

それは何をしませんか?

ブラウザのURLが変更されても、ページ全体がリロードされることはありません。URLを変更した後にページをリロードするには、下位レベルのAPIである$window.location.hrefを使用します。

ソース:https ://docs.angularjs.org/guide/$location

于 2015-08-04T21:51:43.287 に答える
3

私はページリダイレクト(ログインからホームページへ)のために以下を行っています。ユーザーオブジェクトをホームページにも渡す必要があります。だから、私はwindowslocalstorageを使用しています。

    $http({
        url:'/login/user',
        method : 'POST',
        headers: {
            'Content-Type': 'application/json'
          },
        data: userData
    }).success(function(loginDetails){
        $scope.updLoginDetails = loginDetails;
        if($scope.updLoginDetails.successful == true)
            {
                loginDetails.custId = $scope.updLoginDetails.customerDetails.cust_ID;
                loginDetails.userName = $scope.updLoginDetails.customerDetails.cust_NM;
                window.localStorage.setItem("loginDetails", JSON.stringify(loginDetails));
                $window.location='/login/homepage';
            }
        else
        alert('No access available.');

    }).error(function(err,status){
        alert('No access available.');      
    });

そしてそれは私のために働いた。

于 2013-05-27T09:49:39.177 に答える
2

を使用する代わりにsuccess、に変更するthenと機能します。

コードは次のとおりです。

lgrg.controller('login', function($scope, $window, $http) {
    $scope.loginUser = {};

    $scope.submitForm = function() {
        $scope.errorInfo = null

        $http({
            method  : 'POST',
            url     : '/login',
            headers : {'Content-Type': 'application/json'}
            data: $scope.loginUser
        }).then(function(data) {
            if (!data.status) {
                $scope.errorInfo = data.info
            } else {
                //page jump
                $window.location.href = '/admin';
            }
        });
    };
});
于 2016-03-24T13:52:09.893 に答える
1

使用:$ window.location.href ='/Home.html';

于 2017-01-18T06:22:13.723 に答える
0

それは非常に簡単なコードです..しかし罰金を科すのは難しいです..

detailsApp.controller("SchoolCtrl", function ($scope, $location) { 
      $scope.addSchool = function () {

        location.href='/ManageSchool/TeacherProfile?ID=' + $scope.TeacherID;
      }
});
于 2017-03-20T03:34:32.780 に答える