angular中的路由简单使用

  在单页面应用程序中比如angular应用,我们需要根据url的变化(即:不同的请求),来分配不同的资源。根据请求的URL来决定执行哪个模块,这个过程叫路由,同时,我们需要设计路由规则。

  下面给出一个简单的小demo:

<!DOCTYPE html>  
<html>  
<head>  
    <Meta charset="UTF-8">  
    <title>angularJS路由</title>  
</head>  
<body ng-app='rootApp'>
  <ul>
    <li><a href='#/'>主页</a></li>
    <li><a href='#/floor1'>一楼</a></li>
    <li><a href='#/floor2'>二楼</a></li>
  </ul>
  <!-- ng-view 渲染站位 -->
  <div ng-view></div>
</body>
<!-- 下面是渲染模板 -->
<script id='tmpl' type='text/ng-template'>
  <h1>{{placeholder}}</h1>
</script>
    <script src="jquery-1.8.3.js"></script> 
	<script src="angular1.2.9.js"></script>
	<script src='angular-route.min.js'></script>
    <script src="app.js"></script>
</body>
</html>

app.js

/* 此处定义模块,由于需要设定路由,所以要注入ngRoute */
var rootApp = angular.module('rootApp',['ngRoute']);
/* 定义路由表(路由规则)*/
rootApp.config(['$routeProvider',function($routeProvider) {
  /* $routeProvider 就相当于交通警察,根据when和otherwise指挥路由走向 */
  $routeProvider
    .when('/',{
      // 当请求的“URL” /,找当前定义控制器和视图
      controller: 'DefaultController',/* template: '<h1>{{hello}}</h1>' */
      templateUrl: 'tmpl'
    })
    .when('/floor1/1',{
      controller: 'Floor1',templateUrl: 'tmpl'
    })
    /* 这里用:id这种形式来保存路由参数,以便后来用$routeParams可以取到 */
    .when('/floor2/:id/:name/:age',{
      controller: 'Floor2',templateUrl: 'tmpl'
    })
    .otherwise({
      /* 都不匹配,定向到根目录 */
      redirectTo: '/'
    });
}]);

// 定义相关控制器
rootApp.controller('DefaultController',['$scope',function($scope) {
  $scope.placeholder= '当前为主页';
}]);
rootApp.controller('Floor1',function($scope) {
  $scope.placeholder = '当前为1楼';
}]);
rootApp.controller('Floor2','$routeParams',function($scope,$routeParams) {
  /* $routeParams 用于解析请求参数 */
  console.log($routeParams);
  $scope.placeholder= '当前为2楼';
}]);

运行效果

  输入file:///C:/Users/bijian/Desktop/Angular%20route/app.html#/,显示“当前为主页”。


  输入file:///C:/Users/bijian/Desktop/Angular%20route/app.html#/floor1/1,显示“当前为1楼”。


  输入file:///C:/Users/bijian/Desktop/Angular%20route/app.html#/floor2/2/lisi/18,显示“当前为2楼”。

总结

  angular中的路由需要使用它的ngRoute模块,具体使用方法如上所示,其中路由表的设计是通过模块配置$routeProvider的when和otherwise来处理不同的请求参数。

  其中ng-view用于占坑,when中的template或者是templateUrl用于渲染控制层定义的数据,去填这个坑,其中路由参数是根据:parmName 来指定,通过$routeParams来解析参数。

文章来源:http://blog.csdn.net/Tyro_java/article/details/51532135

相关文章

AngularJS 是一个JavaScript 框架。它可通过 注:建议把脚本放在 元素的底部。这会提高网页加载速度,因...
angluarjs中页面初始化的时候会出现语法{{}}在页面中问题,也即是页面闪烁问题。出现这个的原因是:由于...
AngularJS 通过被称为指令的新属性来扩展 HTML。AngularJS 指令AngularJS 指令是扩展的 HTML 属性,带有...
AngularJS 使用表达式把数据绑定到 HTML。AngularJS 表达式AngularJS 表达式写在双大括号内:{{ expres...
ng-repeat 指令可以完美的显示表格。在表格中显示数据 {{ x.Name }} {{ x.Country }} 使用 CSS 样式为了...
$http是 AngularJS 中的一个核心服务,用于读取远程服务器的数据。读取 JSON 文件下是存储在web服务器上...