Angular ui-路由和 Asp.net 路由不工作
Angular ui-routing and Asp.net Route not Working
我是 Angular 的新手,我正在尝试使用参数做一个示例。不带参数的可以正常使用,带参数的link就不行了。我在这里做错了什么?
应用程序和控制器:
var myApp = angular.module('myApp', ['ui.router']);
myApp.config(['$routeProvider','$locationProvider', '$httpProvider',
function ($routeProvider, $locationProvider, $httpProvider) {
$locationProvider.hashPrefix('!').html5Mode(true);
$routeProvider
.when('/NewOrder', {
templateUrl: 'templates/NewOrder',
controller: 'AddOrderController'
}).when('/ShowOrders/:orderID', {
templateUrl: function (params) {return '/templates/ShowOrders?orderID=' + params.orderID; },
controller: 'ShowOrdersController'
}).otherwise({
redirectTo: '/ShowOrders'
});
}
]);
myApp.controller('AddOrderController', function ($scope) {
$scope.message = 'This is the add new order controller screen';
});
myApp.controller('ShowOrdersController', function ($scope,$routeParams) {
$scope.message = 'This is the show orders controller';
$scope.order_id = $routeParams.orderID;
});
Route.config 文件:
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
name: "NewOrder",
url: "templates/NewOrder",
defaults: new { controller = "Templates", action = "AddOrder" });
routes.MapRoute(
name: "ShowOrders",
url: "templates/ShowOrders/{orderID}",
defaults: new { controller = "Templates", action = "ShowOrders", orderID = "" });
routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
);
routes.MapRoute(
name: "Defaults",
url: "{*url}",
defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
);
html 文件:
<!DOCTYPE html>
<html lang="en" ng-app="myApp" ng-strict-di>
<head>
<title>AngularJS Routing example</title>
</head>
<body>
<div class="container">
<div class="row">
<div class="col-md-3">
<ul class="nav">
<li><a href="/NewOrder"> Add New Order </a></li>
<li><a href="/ShowOrders/123"> Show Order </a></li>
</ul>
</div>
<div class="col-md-9">
<div ng-view></div>
</div>
</div>
</div>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-router/0.2.15/angular-ui-router.js"></script>
@*<script src="app.js"></script>*@
<script src="~/Scripts/myApp.js"></script>
</body>
编辑 注意 - 根据 Charlietfl 下面的评论,这是错误的答案。根据 Stack overflow 的偏好,我不会删除它,因为有错误的内容有时也可以帮助引导用户找到答案。
你不得不原谅,因为从 angular + MVC4 开始已经一年多了……我什至不确定这是否值得 "answer"评论
但是
我对 angular 路由的记忆是它们仅基于散列之后发生的事情发生(除非配置设置)
能否花点时间测试一下路线:
/ShowOrders/123#/ShowOrders/123
看看有没有什么变化?同时,我将完成一些旧代码,看看我是否可以回忆起 angular 路由的挑剔部分。
首先你不应该混淆 angular-router
和 ui-router
,因为你目前使用的是 angular-route
,因此你应该使用 ngRoute
模块而不是 ui-router
var myApp = angular.module('myApp', ['ngRoute'/*, otherDependencies */]);
You can not have params
inside your templateUrl
function 在使用 angular 的 1.0.7
版本时,您应该使用最新版本,它添加了支持,您可以在 [=21] 中使用 $routeParmas
=] templateUrl 函数(实际上 angular 自 1.1+ 起添加了此支持)。
或者如果您出于某种原因想坚持使用旧版本,那么您可以将 $routeParams
作为依赖项包含在 .config
函数中。
.when('/ShowOrders/:orderID', {
templateUrl: '/templates/ShowOrders?orderID=' + $routeParams.orderID,
controller: 'ShowOrdersController'
})
我是 Angular 的新手,我正在尝试使用参数做一个示例。不带参数的可以正常使用,带参数的link就不行了。我在这里做错了什么?
应用程序和控制器:
var myApp = angular.module('myApp', ['ui.router']);
myApp.config(['$routeProvider','$locationProvider', '$httpProvider',
function ($routeProvider, $locationProvider, $httpProvider) {
$locationProvider.hashPrefix('!').html5Mode(true);
$routeProvider
.when('/NewOrder', {
templateUrl: 'templates/NewOrder',
controller: 'AddOrderController'
}).when('/ShowOrders/:orderID', {
templateUrl: function (params) {return '/templates/ShowOrders?orderID=' + params.orderID; },
controller: 'ShowOrdersController'
}).otherwise({
redirectTo: '/ShowOrders'
});
}
]);
myApp.controller('AddOrderController', function ($scope) {
$scope.message = 'This is the add new order controller screen';
});
myApp.controller('ShowOrdersController', function ($scope,$routeParams) {
$scope.message = 'This is the show orders controller';
$scope.order_id = $routeParams.orderID;
});
Route.config 文件:
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
name: "NewOrder",
url: "templates/NewOrder",
defaults: new { controller = "Templates", action = "AddOrder" });
routes.MapRoute(
name: "ShowOrders",
url: "templates/ShowOrders/{orderID}",
defaults: new { controller = "Templates", action = "ShowOrders", orderID = "" });
routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
);
routes.MapRoute(
name: "Defaults",
url: "{*url}",
defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
);
html 文件:
<!DOCTYPE html>
<html lang="en" ng-app="myApp" ng-strict-di>
<head>
<title>AngularJS Routing example</title>
</head>
<body>
<div class="container">
<div class="row">
<div class="col-md-3">
<ul class="nav">
<li><a href="/NewOrder"> Add New Order </a></li>
<li><a href="/ShowOrders/123"> Show Order </a></li>
</ul>
</div>
<div class="col-md-9">
<div ng-view></div>
</div>
</div>
</div>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-router/0.2.15/angular-ui-router.js"></script>
@*<script src="app.js"></script>*@
<script src="~/Scripts/myApp.js"></script>
</body>
编辑 注意 - 根据 Charlietfl 下面的评论,这是错误的答案。根据 Stack overflow 的偏好,我不会删除它,因为有错误的内容有时也可以帮助引导用户找到答案。
你不得不原谅,因为从 angular + MVC4 开始已经一年多了……我什至不确定这是否值得 "answer"评论
但是
我对 angular 路由的记忆是它们仅基于散列之后发生的事情发生(除非配置设置)
能否花点时间测试一下路线:
/ShowOrders/123#/ShowOrders/123
看看有没有什么变化?同时,我将完成一些旧代码,看看我是否可以回忆起 angular 路由的挑剔部分。
首先你不应该混淆 angular-router
和 ui-router
,因为你目前使用的是 angular-route
,因此你应该使用 ngRoute
模块而不是 ui-router
var myApp = angular.module('myApp', ['ngRoute'/*, otherDependencies */]);
You can not have params
inside your templateUrl
function 在使用 angular 的 1.0.7
版本时,您应该使用最新版本,它添加了支持,您可以在 [=21] 中使用 $routeParmas
=] templateUrl 函数(实际上 angular 自 1.1+ 起添加了此支持)。
或者如果您出于某种原因想坚持使用旧版本,那么您可以将 $routeParams
作为依赖项包含在 .config
函数中。
.when('/ShowOrders/:orderID', {
templateUrl: '/templates/ShowOrders?orderID=' + $routeParams.orderID,
controller: 'ShowOrdersController'
})