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-routerui-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'
})