AngularJS实现路由实例
发布时间 - 2026-01-10 23:00:13 点击率:次1、首先我们要引进angular.js和angular-route.js文件

复制代码 代码如下: <script type="text/javascript" src=lib/angular.min.js></script><script type="text/javascript" src=lib/angular-route.js></script>
2、然后我们要在html中创建锚点和容器(ng-view)
<a href="#first" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" > 第一页 </a> <a href="#second" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" > 第二页 </a> <div ng-view></div>
3、在模块中注入ngRoute依赖
复制代码 代码如下: angular.module('myApp',['ngRoute'])
4、配置路由
config(['$routeProvider',function ($routeProvider) {
$routeProvider.when('/first',{
template : '<h1> first </h1>'
})
.when('/second',{
template : '<h1> second </h1>'
})
.otherwise({
redirectTo : '/first'
})
}])
效果展示:
完整代码:
<!DOCTYPE html>
<html ng-app="myApp">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script type="text/javascript" src=lib/angular.min.js></script>
<script type="text/javascript" src=lib/angular-route.js></script>
</head>
<body>
<a href="#first" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" > 第一页 </a>
<a href="#second" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" > 第二页 </a>
<div ng-view></div>
<script type="text/javascript">
angular.module('myApp',['ngRoute'])
.config(['$routeProvider',function ($routeProvider) {
$routeProvider.when('/first',{
template : '<h1> first </h1>'
})
.when('/second',{
template : '<h1> second </h1>'
})
.otherwise({
redirectTo : '/first'
})
}])
</script>
</body>
</html>
接下来我们做一个模拟项目路由
1、首先我们看一下我们所需要的文件
所有文件展示
2、之后我们看一下效果图
有两个页面,first page跟second page,点击两个按钮,切换不同页面,展示不同样式
3、好了。我们看一下代码吧!
index.html
<!DOCTYPE html> <html ng-app='myApp'> <head> <meta charset="UTF-8"> <title>Document</title> <script type="text/javascript" src="lib/angular.min.js" ></script> <script type="text/javascript" src="lib/angular-css.js" ></script> <script type="text/javascript" src="lib/angular-route.js" ></script> </head> <body> <a href="#first" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >First Page</a> <a href="#second" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >Second Page</a> <div ng-view></div> <script type="text/javascript" src='app.js'></script> <script type="text/javascript" src='js/services.js'></script> <script type="text/javascript" src='js/controller.js'></script> </body> </html>
代码解释:
首先我们要引进三个文件
1)angular.min.js----angularJS脚本
2)angular-css.js----用来转化css的脚本
3)angular-route.js----路由脚本
然后我们需要两个锚点
<a href="#first" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >First Page</a> <a href="#second" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >Second Page</a>
最后我们需要一个路由导入的容器
复制代码 代码如下: <div ng-view></div>
之后我们将路由的配置、服务、控制器分别放在app.js、services.js、controller.js文件中,便于代码的管理、维护。
4、接下来我们看一下路由的部分
angular.module('myApp',['ngRoute','angularCSS'])
.config(['$routeProvider',function ($routeProvider) {
$routeProvider
.when('/first',{
templateUrl : './view/first.html',
controller : 'FirstCtrl as firstCtrl'
})
.when('/second',{
templateUrl : './view/second.html',
controller : 'SecondCtrl as secondCtrl'
})
.otherwise({
redirectTo : '/first'
})
}])
代码解释:
1)首先,第一行,在myApp模块中注入ngRoute跟angularCSS依赖。
2)然后配置路由(config):
AngularJS 模块的 config 函数用于配置路由规则。通过使用 configAPI,我们请求把$routeProvider注入到我们的配置函数并且使用$routeProvider.whenAPI来定义我们的路由规则。
$routeProvider 为我们提供了 when(path,object) & otherwise(object) 函数按顺序定义所有路由,函数包含两个参数:
第一个参数是 URL 或者 URL 正则规则。第二个参数是路由配置对象。
3)controller
function、string或数组类型,在当前模板上执行的controller函数,生成新的scope。
4)controllerAs
string类型,为controller指定别名。
5)redirectTo
重定向的地址
6)resolve
指定当前controller所依赖的其他模块。
路由设置对象总览:
5、下面我们看一下服务部分,service.js
angular.module('myApp')
.factory('FirstService',[function () {
var list = [
{ name : 'Rose',age : 10 },
{ name : 'Tom',age : 19 }
];
return {
getList : function () {
return list;
}
}
}])
注意:angular.module('myApp')不需要注入依赖
6、下面看一下控制器集成,controller.js
angular.module('myApp')
.controller('FirstCtrl',['$css','FirstService',function ($css,$service) {
var self = this;
$css.add('css/first.css');
self.list = function () {
return $service.getList();
}
}])
.controller('SecondCtrl',['$css','FirstService',function ($css,$service) {
var self = this;
$css.add('css/second.css');
self.list = function () {
return $service.getList();
}
}])
代码分析:
1)在控制器中注入服务依赖以及#css依赖
复制代码 代码如下: controller('FirstCtrl',['$css','FirstService',function ($css,$service)
2)添加css依赖路径
复制代码 代码如下: $css.add('css/first.css');
注意:angular.module('myApp')不需要注入依赖
7、好了。逻辑的部分已经完成了,下面展示一下我们的样式以及结构部分吧
first.html
<div class='first'>
<h1> First Page </h1>
<div ng-repeat="p in firstCtrl.list()">
{{ p.name }} == {{ p.age }}
</div>
</div>
second.html
<div class='second'>
<h1> Second Page </h1>
<div ng-repeat="p in secondCtrl.list()">
{{ p.name }} == {{ p.age }}
</div>
</div>
first.css
.first{
background-color: yellow;
}
.first *{
color: red;
}
second.css
.second{
background-color: skyblue;
}
.second *{
color: green;
}
# angularjs
# 路由实例
# angularjs小项目实例
# 项目实例
# Angularjs制作简单的路由功能demo
# 使用AngularJS对路由进行安全性处理的方法
# AngularJS 路由详解和简单实例
# AngularJS 路由和模板实例及路由地址简化方法(必看)
# AngularJS监听路由的变化示例代码
# 简单讲解AngularJS的Routing路由的定义与使用
# AngularJS通过ng-route实现基本的路由功能实例详解
# AngularJs ng-route路由详解及实例代码
# 看一下
# 好了
# 不需要
# 第一页
# 放在
# 第一个
# 要在
# 第二个
# 做一个
# 所需要
# 重定向
# 器中
# 完成了
# 有两个
# config
# routeProvider
# div
# Document
# DOCTYPE
# myApp
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门
Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】
nodejs redis 发布订阅机制封装实现方法及实例代码
Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能
如何在宝塔面板中修改默认建站目录?
Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面
Laravel Admin后台管理框架推荐_Laravel快速开发后台工具
如何在阿里云服务器自主搭建网站?
Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知
Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
Laravel怎么生成URL_Laravel路由命名与URL生成函数详解
Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
Python图片处理进阶教程_Pillow滤镜与图像增强
如何在局域网内绑定自建网站域名?
用yum安装MySQLdb模块的步骤方法
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践
软银砸40亿美元收购DigitalBridge 强化AI资料中心布局
北京网站制作公司哪家好一点,北京租房网站有哪些?
百度浏览器如何管理插件 百度浏览器插件管理方法
b2c电商网站制作流程,b2c水平综合的电商平台?
Laravel如何与Docker(Sail)协同开发?(环境搭建教程)
JS弹性运动实现方法分析
如何在服务器上三步完成建站并提升流量?
如何在云指建站中生成FTP站点?
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
图册素材网站设计制作软件,图册的导出方式有几种?
新三国志曹操传主线渭水交兵攻略
如何在香港免费服务器上快速搭建网站?
如何在阿里云虚拟服务器快速搭建网站?
Python高阶函数应用_函数作为参数说明【指导】
php静态变量怎么调试_php静态变量作用域调试技巧【解答】
Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】
如何在阿里云域名上完成建站全流程?
如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框
Laravel如何使用Gate和Policy进行授权?(权限控制)
html5如何实现懒加载图片_ intersectionobserver api用法【教程】
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
利用vue写todolist单页应用
JavaScript如何实现路由_前端路由原理是什么
Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程
如何在云主机快速搭建网站站点?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
详解MySQL数据库的安装与密码配置
html如何与html链接_实现多个HTML页面互相链接【互相】
如何用IIS7快速搭建并优化网站站点?
如何在景安服务器上快速搭建个人网站?
如何在新浪SAE免费搭建个人博客?

