内容介绍,为什么要使用前端路由?

在2005左右,兴起了一种叫做ajax的技术,有了ajax之后,我们向服务端提交数据的时候就不再需要使用from表单去提交了,因为from表单之间的提交会导致页面之间的切换,也就是说无法实现单页应用。 
ajax的缺陷 
1、不会在浏览器里面留下历史记录 
2、用户无法将页面加为书签保存下来或者无法通过发送网址给其他人,其他人通过直接点击网址进入这个页面 
3、ajax无法实现SEO优化,ajax对搜索引擎是不友好的 
这也是为什么要使用前端路由的一个原因。

首先我们来看一下app.js这个入口文件

 var bookStoreApp = angular.module('bookStoreApp',['ngRoute','ngAnimate','bookStoreCtrls','bookSroreFilters','bookStoreServices','bookStoreDirective']);

 bookStore.config(function($routeProvider){
$routeProvider:when('/hello',{
temolateUrl:'tpls/hello.html',
controller:'HelloCtrl'
}).when('/list',{
temolateUrl:'tpls/bookList.html',
controller:'BookListCtrl'
}).otherwise({
redirectTo:'/hello'
})
});

我们定义一个模块,叫做bookStoreApp, 
我们在上面调用config这个方法, 
大家会发现有个routeProvider,前面有一个$$符号,这个是AngularJS自身所提供的路由机制, 
根据$routeProvider我们来进行路由的配置,

如:当浏览器地址栏发现地址是hello这样一个地址的时候,他就会使用tpls/hello.html这样的一个模板, 
有HelloCtrl这个控制器,来处理模板和数据之间的绑定,

当他发现浏览器地址栏发现地址是list这样一个地址的时候,他就会调用另外一个模板, 
其他所有的情况都会直接跳到hello,

这里大家需要注意的是,AngularJS1.2以后,把机制之间做了模块化的处理,也就是route没有包含在Angular.js这个文件里面,而是把它独立出来成了一个模块, 
大家可以看一下下面的目录图,看一下angularJS里面的模块是如何进行切分的,

angularJS不再像以前一样,把所有的文件都合在angular.js这个文件里面, 
而是切分成一个个独立的js文件了,

所以这就导致了当我们需要使用路由的时候,一定要在页面上手动导入angular-route.js文件,

 <script src="framework/1.3.0.14/angular-route.js"></script>

如果你忘了加,浏览器可能会提示routeProvider不是对象或者没找到,如果你发生这个问题,你一定要检查一下页面有没有导入angular-route.js文件

【提示】这个是AngularJS本身自带的路由机制,这个路由有一个缺陷,它是无法实现深层次嵌套的路由的 
所有就有第三方开发了一个叫做Router

欢迎了解https://angular-ui.github.io/ ,https://ui-router.github.io/ng1/docs/0.3.1/index.html#/api/ui.router查看详情

UI-Router提供了一种很好的机制,可以实现深层次嵌套

首先你需要从github上,将UI-Router这个包下载下来,然后导入到页面中

 <script src="framework/1.3.0.14/angular-ui-router.js"></script>

如果你使用了angular-ui-router.js,你就不需要使用angularJS原生的routeProvider了, 
写法上也会发生一定的变化,

 <body>
//写一个指令,这表示的是一个视图
<div ui-view></div>
</body>

我们看一下js部分,这里我们不在使用routeProvider了,其实用法上大同小异, 
换成另外连个$$stateProvider, $urlRouterProvider, 
urlRouterProvider用法和angularjs原生的routeProvider写法上非常相似, 
但是stateProvider它定义的方法名叫做state,

首先我们要调用stateProvider上面的state方法,我们来配置当浏览器地址栏发生变化的时候使用什么样的模板, 
这里有很多比较快捷的语法 
我们可以看到html里面只有单个的div,如何使用div去填充首页的内容呢?

 <div ui-view></div>

我们看js,首先有个url参数’/index’, 
并且views里面填充了好几组内容,其实是三组view, 
我们的页面分成两个部分,顶部是一个导航条,然后下面的内容是会跟着切换的, 
顶部我们写一个空的字符串”,我们利用tpls3/index.html作为我们主页的html模板, 
在tpls3/index.html模板里面,我们又把模板分成了两块,一个叫topbar一个叫main,

 <div class="container">
<div ui-view="topbar"></div>
<div ui-view="main"></div>
</div>

我们可以看到js里面有个topbar@index,下面有个叫做main@index, 
通过@这样的语法,stateProvider就知道每个小块自动加载什么样的模板,

我们可以看到下面的state写法都差不多,当然可以看到index.usermng,index.usermng.highendusers等, 
也就是说可以用‘’点‘’来分割子模块子区域, 
这样的话,有了ui-view以后,我们就可以使用这种深层次的嵌套了 
包括一个页面上分成多个区域,多个区域都可以定义命名的ui-view, 
这样可以只切换其中的一小块区域,而不用整体切换

前端路由基本原理

哈希# 
可以实现,浏览器不刷新页面,实现url地址的变化,大部分浏览器均可支持

HTML5中history API 
我们可以通过js代码去修改URL地址栏里面的地址,这样的话,浏览器会留下历史记录,但是页面不会跳转

路由的核心是给应用定义“状态”

使用路由机制会影响到应用的整体编码方式(需要预先定义好状态)

考虑兼容性问题与“优雅降级” 
会检查浏览器,如果浏览器比较旧会使用哈希的方式,如果是新的浏览器会使用HTML5中history API的方式

第220天:Angular---路由的更多相关文章

  1. angular路由——ui.route

    angular路由 使用案例 <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...

  2. angular路由详解:

    1.$routeProvider ngRoute模块中的服务 2.otherwise:设置用于路由改变时,与任何其他定义的路由无法匹配的时候执行的代码 3.when:为$route服务定义新的路由 例 ...

  3. angular 路由的引用

    使用angular路由 遇到的坑. 使用cmd 安装好node.js 安装成功 输入node  -v 能查看版本说明安装成功 搭建angular项目输入命令 npm install  -g  angu ...

  4. angular 路由项目例子

    angular 路由是我在工作中体验非常便捷的一点, 这是详细的API ,查看API 可以了解很多东西, https://github.com/angular-ui/ui-router/wiki/Qu ...

  5. Angular路由参数传递

    一.路由时传递参数的方式 1.在查询参数中传递数据 //页面 <a routerLink="/product" [queryParams]="{id:1}" ...

  6. angular路由(自带路由篇)

    一.angular路由是什么? 为了实现SPA多视图的切换的效果,其原理可简述为每个 URL 都有对应的视图和控制器.所以当我们给url后面拼上不同的参数就能通过路由实现不同视图的切换. 二.文件总览 ...

  7. Angular路由守卫 canActivate

    作用 canActivate 控制是否允许进入路由. canActivateChild 等同 canActivate,只不过针对是所有子路由. 关键代码 创建路由守卫 import { Injecta ...

  8. Angular路由守卫 canDeactivate

    目的 离开页面时,做出逻辑判断 以ng-alain的项目为基础做演示 效果如图: 关键代码 定义一个CanDeactivateGuardService export class CanDeactiva ...

  9. Angular 路由守卫

    1. 路由 Angular路由: 可以控制页面跳转:可以在多视图间切换: 2. 路由守卫 Angular路由守卫: 在进入或离开某路由时,用于判断是否可以离开.进入某路由::: return true ...

  10. angularjs中使用锚点,angular路由导致锚点失效的两种解决方案

     壹 ❀ 引 公司新项目开发中,首页要做个楼层导航效果(如下图),要求能点击图标对应跳到楼层即可,因为不需要跳转过度动画,也要求最好别用JQ,想着原生js操作dom计算top的兼容性,想着用锚点实现算 ...

随机推荐

  1. Zabbix实战-简易教程--业务类

    一.需求 项目要求对线上服务器进行监控,包括服务器本身状态.进程相关数据.业务相关数据. 服务器本身状态可以通过基础模板即可获取数据(CPU.内存.网络.磁盘): 进程相关数据,前面也有相关文章专门监 ...

  2. 180815-Spring之RestTemplate中级使用篇

    Spring之RestTemplate中级使用篇 前面一篇介绍了如何使用RestTemplate发起post和get请求,然而也只能满足一些基本的场景,对于一些特殊的如需要设置请求头,添加认证信息等场 ...

  3. 求二维数组最大子数组的和。郭林林&胡潇丹

    求二维数组子数组的最大值,开始思路不太清晰.先从最简单的开始. 以2*2的简单数组为例找规律, 假设最大数为a[0][0],则summax=a[0][0],比较a[0][0]+a[0][1].a[0] ...

  4. php从入门到放弃系列-03.php函数和面向对象

    php从入门到放弃系列-03.php函数和面向对象 一.函数 php真正的威力源自它的函数,内置了1000个函数,可以参考PHP 参考手册. 自定义函数: function functionName( ...

  5. 北美跨境电商平台Wish透露未来一年在华规划

    9月12日,北美跨境电商平台Wish在深圳透露了未来一年在中国区的重点规划.Wish中国区总裁丁浩川表示,在下一阶段,Wish公司将继续围绕 提升平台流量. 加强品类支撑. 深化库存管理. 推进物流改 ...

  6. ansible使用1

    常用软件安装及使用目录   ansible软件2 ### ansible软件部署安装需求#### 01. 需要有epel源 系统yum源(base epel--pip gem) sshpass---e ...

  7. 编写webpack 插件

    Webpack插件为第三方开发者释放了Webpack的最大可能性.利用多级回调开发者可以把他们自己的需要的功能引入到Webpack里面来.Build插件比Build loader 更进一步.因为你需要 ...

  8. 解决 vuex mapGetters 语法报错 (Unexpected token )

    在使用vuex2的mapGetters 和 mapActions 的方法时,借助 stage2 的 Object Rest Operator 特性,可以写出下面代码:  computed: { ... ...

  9. CMD命令操作符

    cmd                   command的缩写,是windows环境下的虚拟DOS窗口,提供有DOS命令,功能强大 mstsc                 远程 inetmgr  ...

  10. 软工实践-Beta 冲刺 (7/7)

    队名:起床一起肝活队 组长博客:博客链接 作业博客:班级博客本次作业的链接 组员情况 组员1(队长):白晨曦 过去两天完成了哪些任务 描述: 1.界面的修改与完善 展示GitHub当日代码/文档签入记 ...