gpt4 book ai didi

javascript - 当用于另一个网站中的单页应用程序时,AngularJS 应用程序会破坏后退按钮

转载 作者:搜寻专家 更新时间:2023-11-01 04:22:31 25 4
gpt4 key购买 nike

注意:我使用的是 AngularJS v1.6.0

我已经在另一个现有网站中实现了一个独立的 AngularJS 应用程序,它存在于网站的单个页面上,网站的其余部分没有运行任何 Angular 代码。

例如,站点上的常规页面可能位于:

http://example.com/any-page

然后用户可以点击一个链接,它会将他们带到上面运行着 Angular JS 的页面:

http://example.com/angularjs-app

当登陆此 URL 时,它会加载 AngularJS 应用程序并按预期将 #!/ 附加到 URL。它不包含网站其余部分的任何元素,例如标题,因此对于用户来说,它看起来像是一个完全不同的部分。但是,它也会破坏后退按钮。不可能按返回键返回到 http://example.com/any-page。每次按下返回键时,它只会再次加载 AngularJS 应用程序的登陆 View - 实际上,用户会停留在 AngularJS 应用程序页面上,无法返回到 /any-page

我认为这与 AngularJS 路由有关,因为它似乎会在您按下返回时刷新 URL 的 #!/ 部分,并且只是重新加载应用程序的初始 View 。但我可能是错的。

请注意,在访问各种路线时,后退按钮在 AngularJS 应用程序中工作正常。例如,如果我在应用程序中的各种路由/ View 之间导航,例如 #!/login#!/view-details,我总是可以通过这些返回通过后退按钮查看。但当它到达初始 View 时,它就停止工作了。

有人知道解决这个问题的方法吗?

注意:我查看了关于此的各种其他 Stack Overflow 帖子,但是它们似乎都与后退按钮根本不起作用有关,而不是后退按钮用于在内部路由之间导航的问题应用程序,但不会返回到网站上的原始非 AngularJS 页面。

路由配置

(function () {
"use strict";

var routes = {
error: "/error",
forgottenPassword: "/forgotten-password",
home: "/home",
login: "/login",
orders: "/orders",
paymentDetails: "/payment-details",
personalDetails: "/personal-details",
subscriptions: "/subscriptions",
updatePassword: "/update-password",
accountVerification: "/account-verification",
register: '/register',
profile: '/profile',
accountConfirm: '/account-confirm',
deleteAccount: '/delete-account'
};

var configFunc = function (
$routeProvider,
$locationProvider,
CONFIG,
ROUTES) {

var resolve = {
isLoggedIn: [
"$q", "ERRORS", "core.services.sessionsService", function ($q, ERRORS, sessionsService) {
return sessionsService.isLoggedIn().then(function (isLoggedIn) {
if (isLoggedIn) {
return isLoggedIn;
}

return $q.reject({ error: ERRORS.route.requiresAuth });
});
}
]
};

var getTemplateUrl = function(page) {
return CONFIG.rootPagesUrl + page;
};

$routeProvider
.when("/", {
controller: "StartCtrl",
template: ""
})
.when(ROUTES.login, {
templateUrl: getTemplateUrl("login.html"),
pageName: "Login"
})
.when(ROUTES.forgottenPassword, {
templateUrl: getTemplateUrl("forgotten-password.html"),
pageName: "Forgotten Password"
})
.when(ROUTES.home, {
templateUrl: getTemplateUrl("home.html"),
resolve: resolve
})
.when(ROUTES.personalDetails, {
templateUrl: getTemplateUrl("personal-details.html"),
resolve: resolve
})
.when(ROUTES.paymentDetails, {
templateUrl: getTemplateUrl("payment-details.html"),
resolve: resolve
})
.when(ROUTES.orders, {
templateUrl: getTemplateUrl("orders.html"),
resolve: resolve
})
.when(ROUTES.subscriptions, {
templateUrl: getTemplateUrl("subscriptions.html"),
resolve: resolve
})
.when(ROUTES.updatePassword, {
templateUrl: getTemplateUrl("update-password.html"),
pageName: "Update Password"
})
.when(ROUTES.accountVerification, {
templateUrl: getTemplateUrl("account-verification.html"),
pageName: "Account Verification"
})
.when(ROUTES.error, {
templateUrl: getTemplateUrl("error.html"),
pageName: "Error"
})
.when(ROUTES.register, {
templateUrl: getTemplateUrl("register.html"),
pageName: "Register"
})
.when(ROUTES.profile, {
templateUrl: getTemplateUrl("profile.html"),
resolve: resolve,
pageName: "Profile"
})
.when(ROUTES.accountConfirm, {
templateUrl: getTemplateUrl("accountConfirm.html"),
pageName: "Registration Complete"
})
.when(ROUTES.deleteAccount, {
templateUrl: getTemplateUrl("deleteAccount.html"),
resolve: resolve,
pageName: "Delete Account"
})
.otherwise({
templateUrl: getTemplateUrl("login.html"),
pageName: "Login"
});
};

var config = [
"$routeProvider",
"$locationProvider",
"CONFIG",
"ROUTES",
configFunc
];

var module = angular.module("app");
module.constant("ROUTES", routes);
module.config(config);
})();

ng-view 所在的索引部分:

<body ng-app="app" ng-strict-di>

<div>
<div id="container" class="mpp-app">
<div class="mpp-page" id="mpp-page">
<div class="page-wrapper">
<div class="ui-module-container">
<div brand></div>
</div>
<div ng-view></div>
</div>
</div>
<div class="ui-module-container">
<div footer></div>
</div>
</div>
</div>

<div id="spinner" class="hidden"><div class="icon"></div></div>

开始控制

(function () {
"use strict";

var func = function (
$rootScope,
$scope,
$location,
ROUTES,
APP_EVENTS,
CORE_EVENTS,
SessionModel,
sessionsService,
configurationAggregator) {

var broadcast = function(event, args) {
$rootScope.$broadcast(event, args);
};

var redirectToLogin = function() {
broadcast(APP_EVENTS.navigation.login);
};

// check if user is signed in and has a valid session
var verifySession = function() {
sessionsService.verify().then(function() {
// if user is logged in navigate to profile
// otherwise navigate to login
configurationAggregator.getConfiguration().then(function () {
broadcast(APP_EVENTS.auth.login.success);
//broad cast(APP_EVENTS.navigation.home);
broadcast(APP_EVENTS.navigation.uktvProfile);
}, redirectToLogin);
}, redirectToLogin);
};

// init
var sessionId = $location.search().guid;

if (angular.isDefined(sessionId) && sessionId !== null) {
broadcast(CORE_EVENTS.session.changed, { sessionId: sessionId });
verifySession();
} else {
verifySession();
}
};

var controller = [
"$rootScope",
"$scope",
"$location",
"ROUTES",
"EVENTS",
"mpp.core.EVENTS",
"mpp.core.SessionModel",
"mpp.core.services.sessionsService",
"mpp.core.aggregators.configurationAggregator",
func
];

var module = angular.module("app");
module.controller("StartCtrl", controller);
})();

最佳答案

这不是 AngularJS Router 的问题(虽然可能是特定版本的错误,所以请在问题中添加有关版本的信息)。但很可能您在路由器事件的处理程序或 StartCtrl 中有重定向。

AngularJS 教程中的示例运行良好,您可以在此处获取:

git clone https://github.com/angular/angular-phonecat.git

为了定位问题,我会首先尝试使用以下配置运行您的应用:

$routeProvider
.when('/', {
template: '<div>Hello</div>'
})
.when(ROUTES.login, {
templateUrl: getTemplateUrl("login.html"),
pageName: "Login"
})
.when(ROUTES.forgottenPassword, {
templateUrl: getTemplateUrl("forgotten-password.html"),
pageName: "Forgotten Password"
})
.when(ROUTES.home, {
templateUrl: getTemplateUrl("home.html"),
resolve: resolve
})
.when(ROUTES.personalDetails, {
templateUrl: getTemplateUrl("personal-details.html"),
resolve: resolve
})
.when(ROUTES.paymentDetails, {
templateUrl: getTemplateUrl("payment-details.html"),
resolve: resolve
})
.when(ROUTES.orders, {
templateUrl: getTemplateUrl("orders.html"),
resolve: resolve
})
.when(ROUTES.subscriptions, {
templateUrl: getTemplateUrl("subscriptions.html"),
resolve: resolve
})
.when(ROUTES.updatePassword, {
templateUrl: getTemplateUrl("update-password.html"),
pageName: "Update Password"
})
.when(ROUTES.accountVerification, {
templateUrl: getTemplateUrl("account-verification.html"),
pageName: "Account Verification"
})
.when(ROUTES.error, {
templateUrl: getTemplateUrl("error.html"),
pageName: "Error"
})
.when(ROUTES.register, {
templateUrl: getTemplateUrl("register.html"),
pageName: "Register"
})
.when(ROUTES.profile, {
templateUrl: getTemplateUrl("profile.html"),
resolve: resolve,
pageName: "Profile"
})
.when(ROUTES.accountConfirm, {
templateUrl: getTemplateUrl("accountConfirm.html"),
pageName: "Registration Complete"
})
.when(ROUTES.deleteAccount, {
templateUrl: getTemplateUrl("deleteAccount.html"),
resolve: resolve,
pageName: "Delete Account"
})
.otherwise({
templateUrl: getTemplateUrl("login.html"),
pageName: "Login"
});

如果它正常工作,那么您在 StartCtrl Controller 中发生了一些可疑的事情。如果仍然不能正常工作,试试这个:

$routeProvider
.when('/', {
template: '<div>Hello</div>'
})
.otherwise('/');

如果工作正常,则寻找 $routeChangeError 处理程序。如果不是,则可能是任何路由器事件处理程序。以下是 ngRoute 的事件列表:$routeChangeStart$routeChangeError$routeUpdate$routeChangeSuccess

编辑:

由于您不希望用户在单击返回时返回到 / 路线,因此您可以将其从历史记录中删除。只需调用 replace method$location 服务上,当您将用户重定向离开 / 路线时。例如。 $location.path('/login').replace()

关于javascript - 当用于另一个网站中的单页应用程序时,AngularJS 应用程序会破坏后退按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45343877/

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