路由

收藏172

阅读2937

更新时间2025-08-11

什么是 AngularJS 中的路由?

如果您想导航到应用程序中的不同页面,但也希望应用程序成为 SPA(单页应用程序),并且没有页面重载,则可以使用 ngRoute 模块。

ngRoute 模块将您的应用程序路由到不同的页面,而无需重新加载整个应用程序。

实例

导航到 "red.htm"、"green.htm" 和 "blue.htm":



主页

红色 绿色 蓝色
运行实例 »

点击 "运行实例" 按钮查看在线实例

我需要什么?

为了使你的应用程序为路由做好准备,你必须包含 AngularJS Route 模块:


然后,您必须将 ngRoute 添加为应用程序模块中的依赖项:

var app = angular.module("myApp", ["ngRoute"]);

现在您的应用程序可以访问提供 $routeProvider 的路由模块。

请使用 $routeProvider 在应用程序中配置不同的路由:

app.config(function($routeProvider) {
  $routeProvider
  .when("/", {
    templateUrl : "main.htm"
  })
  .when("/red", {
    templateUrl : "red.htm"
  })
  .when("/green", {
    templateUrl : "green.htm"
  })
  .when("/blue", {
    templateUrl : "blue.htm"
  });
});

它去哪里了?

您的应用程序需要一个容器来放置路由提供的内容。

这个容器就是 ng-view 指令。

可以通过三种不同的方式在应用程序中包含 ng-view 指令:

实例

运行实例 »

点击 "运行实例" 按钮查看在线实例

实例


运行实例 »

点击 "运行实例" 按钮查看在线实例

实例

运行实例 »

点击 "运行实例" 按钮查看在线实例

应用程序只能有一个 ng-view 指令,这将是该路由提供的所有视图的占位符。

$routeProvider

使用 $routeProvider,您可以定义当用户单击链接时要显示的页面。

实例

定义 $routeProvider

var app = angular.module("myApp", ["ngRoute"]);
app.config(function($routeProvider) {
  $routeProvider
  .when("/", {
    templateUrl : "main.htm"
  })
  .when("/london", {
    templateUrl : "london.htm"
  })
  .when("/paris", {
    templateUrl : "paris.htm"
  });
});
运行实例 »

点击 "运行实例" 按钮查看在线实例

使用应用程序的 config 方法定义 $routeProvider。在应用程序加载时将执行在 config 方法中注册的工作。

控制器

使用 $routeProvider,您还可以为每个“视图”定义一个控制器。

实例

添加控制器:

var app = angular.module("myApp", ["ngRoute"]);
app.config(function($routeProvider) {
  $routeProvider
  .when("/", {
    templateUrl : "main.htm"
  })
  .when("/london", {
    templateUrl : "london.htm",
    controller : "londonCtrl"
  })
  .when("/paris", {
    templateUrl : "paris.htm",
    controller : "parisCtrl"
  });
});
app.controller("londonCtrl", function ($scope) {
  $scope.msg = "I love London";
});
app.controller("parisCtrl", function ($scope) {
  $scope.msg = "I love Paris";
});
运行实例 »

点击 "运行实例" 按钮查看在线实例

"london.htm" 和 "paris.htm" 是普通的 HTML 文件,您可以在其中添加 AngularJS 表达式,就像在 AngularJS 应用程序的其他 HTML 部分一样。

这些文件看起来像这样:

london.htm

London

London is the capital city of England.

It is the most populous city in the United Kingdom, with a metropolitan area of over 13 million inhabitants.

{{msg}}

paris.htm

Paris

Paris is the capital city of France.

The Paris area is one of the largest population centers in Europe, with more than 12 million inhabitants.

{{msg}}

模板

在前面的例子中,我们在 $routeProvider.when 方法中使用了 templateUrl 属性。

您还可以使用 template 属性,它允许您直接在属性值中编写 HTML,而不是引用页面。

实例

编写模板:

var app = angular.module("myApp", ["ngRoute"]);
app.config(function($routeProvider) {
  $routeProvider
  .when("/", {
    template : "

Main

Click on the links to change this content

" }) .when("/banana", { template : "

Banana

Bananas contain around 75% water.

" }) .when("/tomato", { template : "

Tomato

Tomatoes contain around 95% water.

" }); });
运行实例 »

点击 "运行实例" 按钮查看在线实例

otherwise 方法

在前面的例子中,我们使用了 $routeProvider 的 when 方法。

您还可以使用 otherwise 方法,当其他所有路由都不匹配时,它将成为默认路由。

实例

如果既没有点击 "Banana" 链接也没有点击 "Tomato" 链接,请告诉他们:

var app = angular.module("myApp", ["ngRoute"]);
app.config(function($routeProvider) {
  $routeProvider
  .when("/banana", {
    template : "

Banana

Bananas contain around 75% water.

" }) .when("/tomato", { template : "

Tomato

Tomatoes contain around 95% water.

" }) .otherwise({ template : "

None

Nothing has been selected

" }); });
运行实例 »

点击 "运行实例" 按钮查看在线实例

相关

视频

RELATED VIDEOS

更多

免费

Web前端开发极速入门
初级 Web前端开发极速入门

219920次学习

收藏

免费

前端入门_HTML5
初级 前端入门_HTML5

616946次学习

收藏

免费

30分钟学会网站布局
初级 30分钟学会网站布局

238440次学习

收藏

免费

CSS视频教程-玉女心经版
初级 CSS视频教程-玉女心经版

393054次学习

收藏

免费

独孤九贱(1)_HTML5视频教程

免费

独孤九贱(6)_jQuery视频教程

免费

独孤九贱(7)_Bootstrap视频教程

免费

独孤九贱(2)_CSS视频教程
初级 独孤九贱(2)_CSS视频教程

229605次学习

收藏

科技资讯

更多

精选课程

更多
前端入门_HTML5
前端入门_HTML5

共29课时

61.7万人学习

CSS视频教程-玉女心经版
CSS视频教程-玉女心经版

共25课时

39.3万人学习

JavaScript极速入门_玉女心经系列
JavaScript极速入门_玉女心经系列

共43课时

71万人学习

独孤九贱(1)_HTML5视频教程
独孤九贱(1)_HTML5视频教程

共25课时

61.6万人学习

独孤九贱(2)_CSS视频教程
独孤九贱(2)_CSS视频教程

共22课时

23万人学习

独孤九贱(3)_JavaScript视频教程
独孤九贱(3)_JavaScript视频教程

共28课时

33.9万人学习

独孤九贱(4)_PHP视频教程
独孤九贱(4)_PHP视频教程

共89课时

125万人学习

关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号