角度ui路由和Asp.net路由不工作

时间:2015-10-04 15:12:49

标签: javascript angularjs asp.net-mvc-4 angularjs-routing

我对Angular很新,我试图用参数做一个例子。没有参数的那个工作正常,但与参数的链接不起作用。我在这做错了什么?

应用和控制器:

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>

2 个答案:

答案 0 :(得分:0)

编辑注意 - 根据Charlietfl的评论,这是错误的答案。每个堆栈溢出的首选项我不会删除它,因为有错误的内容有时可以帮助引导用户得到答案。

你不得不原谅因为做角度+ MVC4已经有一年多了......我甚至不确定这应该是对评论的“回答”

但是

我对角度路线的回忆是这样的,它们只发生在散列后发生的事情上(限制配置设置)

你能花一点时间测试路线吗?

 /ShowOrders/123#/ShowOrders/123

并查看是否有任何变化?与此同时,我会通过一些旧的代码来看看我是否能够回忆起角度路由的一些东西。

答案 1 :(得分:0)

首先,你不应该在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在使用1.0.7版本的角色时,您应该使用的最新版本增加了对$routeParmas templateUrl函数中$routerProvider的支持(实际上) angular自1.1 +以来增加了这种支持。

或者,如果您因某些原因想要坚持使用旧版本,那么您可以在$routeParams函数中包含.config作为依赖项。

.when('/ShowOrders/:orderID', {
     templateUrl: '/templates/ShowOrders?orderID=' + $routeParams.orderID,
     controller: 'ShowOrdersController'
})