我正在寻找一种使用 ngRouting 在新窗口中打开模板的方法。我在我的索引页面中设置了一个 ng-view div,它允许我在我的中心页面中填充数据,但是如果用户选择在新窗口/标签中打开一个链接,页面会返回 404,因为它是期望 ngRoute 加载它的控制器和模板。有什么方法可以让 Angular 处理这个选项?
下面是我的索引页
<script type='text/javascript' src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.13/angular.min.js"></script>
<script type='text/javascript' src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.13/angular-route.min.js"></script>
<body ng-controller="routeController" ng-init="init()">
<div id="wrapper" class="page">
<ul id='settingsLink' class='settingsLink' ng-mouseleave="hideSettingsLink()">
<li><a href="index.html#!/login">Login</a></li>
<li><a href="index.html#!/page2">Page 2</a></li>
<li><a href="index.html#!/page3">Page 3</a></li>
</ul>
<div id="viewcontent">
<div ng-view></div>
</div>
</div>
</body>
这是我的 routeController 配置代码:
angular.module('myApp').config(function($routeProvider, $locationProvider, $sceDelegateProvider){
$routeProvider
// route for the Login page
.when('/login', {
templateUrl : 'pages/login.html',
controller : 'AuthenticateController'
})
// route for page 2
.when('/page2', {
templateUrl : 'pages/page2.html',
controller : 'Page2Ctrl'
})
// route for page 3
.when('/page3', {
templateUrl : 'pages/page3.html',
controller : 'Page3Ctrl'
});
$locationProvider
.html5Mode(false)
.hashPrefix('!');
});
假设我要打开第 3 页。如果我右键单击并尝试在新选项卡中打开,我的页面将解析回“index.html#!/login”,而不是“index.html#!/page3”。