我們正在創建一個使用AngularJS ui.router進行客戶端路由的單頁ASP.NET MVC應用程序。如何在ASP.NET MVC中使用ui.router處理AngularJS中的頁面刷新
當前,後退/前進按鈕按預期工作,但當用戶單擊瀏覽器的刷新按鈕時,部分視圖將在沒有佈局頁面的情況下加載。
例如:
- 用戶導航到「http://localhost/MyApp/」,MVC返回佈局頁面,然後我們定位到默認狀態。
- 用戶點擊頁面上的鏈接,導航到通過客戶端路由特定的狀態,網址現在是在瀏覽器的刷新按鈕「http://localhost/MyApp/UserManagement/EditUser」
- 用戶點擊,它加載了「UserManagement/EditUser」局部視圖,而不佈局
我們還需要做什麼才能在用戶單擊瀏覽器的刷新按鈕時重新加載佈局?
public class RouteConfig
{
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
);
}
}
var baseFrameworkApp = angular.module("BaseFrameworkApp", ['ui.router'])
.config(['$stateProvider', '$httpProvider', '$locationProvider', '$urlRouterProvider',
function ($stateProvider, $httpProvider, $locationProvider, $urlRouterProvider) {
$locationProvider.hashPrefix("!").html5Mode(true);
$urlRouterProvider.otherwise("/");
$stateProvider
.state('Default', {
url: '/{controller}/{action}',
views: {
"mainContainer": {
templateUrl: function (params) { return params.controller + '/' + params.action; }
}
}
});
}]);
你能分享你的佈局頁面代碼嗎?我假設你有一個' '標籤。此外,您必須在RouteConfig中提供一個全面的網址。所有沒有'#'的url請求都發送到服務器,因此服務器應該將所有url映射到單個佈局呈現操作 –
v1p