ui-router的使用
使用时需要ui中用ui-view指令指定 如:
<div ui-view></div>
首先配置注册 ui-route
var mainModule = angular.module('main', ['ui.router']);
由于run方法是在angular启动的时候就会执行的,可以将路由跳转控制放到run方法中,比如某种条件下禁止路由跳转 另外全局事件也可以放到run方法中
mainModule.run(function($rootScope,$state,$http,$stateParams){
    //这里把$state和$stateParams这两个对象放到$rootScope上,方便其它地方引用和注入。
    $rootScope.$state = $state;
    $rootScope.$stateParams = $stateParams;
    $rootScope.$on('$stateChangeStart', function(event, toState,
                        toParams, fromState, fromParams) {
                    if (toState.name === "yxlpm") {
                        // 这里加入调出影响力排名页面是做出的判断
                        //使用jquery不使用$http是应为$http的请求是不定时的,等请求完成页面已经完成了跳转,evet事件就无效
                        // 如果好友公司数少于5个侧不显示页面,跳出提示
                        $.ajax({
                                    method : 'POST',
                                    url : '../userInfo/influence',
                                    async: false,
                                    headers : {
                                        'token' : $rootScope.token
                                    }
                                }).success(
                                function(resp, status, headers, config) {
                                    if (resp.code === 8037) {
//                                        $state.go('wo');   路由跳转go方式
                                        event.preventDefault();// 取消默认跳转行为
                                        alert('您的影响力不足无法查看');
                                    }
                                });
                    }
                });
})
基本路由配置
mainModule.config(function($stateProvider, $urlRouterProvider) {
        // $urlRouterProvider.otherwise('../dongtai/smdt.html');
        // //在配置(状态配置和when()方法)中没有找到url的任何匹配
        $stateProvider.state('news', {
                    url : '/news/:type', // 消息   type为参数类型  取参数可用$stateParams.type
                    templateUrl : '../grsz/news.html'
                }).state('sousuo.zrssjg', {
                    url : '/zrssjg/:topic', // 找人结果
                    templateUrl : '../sousuo/zrssjg.html'
                }).state('zwxq', {                    //注意这边嵌套视图的写法
                    url : '/zwxq/:id', // 职位详情
                    views : {
                        'view1' : {
                            templateUrl : '../wo/zwxq.html'
                        },
                        ‘view2’:{
                            templateUrl : '../wo/zlxq.html'
                        }
                    }
                })
    });
    html:
    //传参方式1、/news/1      反斜杆后面为参数
    <a class="menu-item" href="#/news/1" hideblock>
          消息
    </a>
    //传参方式2、topic为参数名    用.号来控制sousuo页面下的子页面
    <a class="tag" ui-sref="sousuo.zrssjg({topic:ChildrenPosition.name})"</a>
    //指定路由
    <div ui-view="view1"></div>
    <div ui-view="view2"></div>
state事件
    //状态改变之前触发
    $rootScope.$on('$stateChangeStart', function(event, toState, toParams, fromState, fromParams){ ... })
    $rootScope.$on('$stateNotFound', function(event, unfoundState, fromState, fromParams){ ... })
    //example
    // somewhere, assume lazy.state has not been defined
$state.go("lazy.state", {a:1, b:2}, {inherit:false});
// somewhere else
$rootScope.$on('$stateNotFound',
function(event, unfoundState, fromState, fromParams){
    console.log(unfoundState.to); // "lazy.state"
    console.log(unfoundState.toParams); // {a:1, b:2}
    console.log(unfoundState.options); // {inherit:false} + default options
})
//状态改变成功之后触发
    $rootScope.$on('$stateChangeSuccess', function(event, toState, toParams, fromState, fromParams){ ... })
    $rootScope.$on('$stateChangeError', function(event, toState, toParams, fromState, fromParams, error){ ... })
view事件
    View被加载但是DOM树构建之前时: 
    $scope.$on('$viewContentLoading', function(event, viewConfig){ ... }); 
    View被加载而且DOM树构建完成时: 
    $scope.$on('$viewContentLoaded', function(event){ ... });
另一种传参方式
    $state.go('sousuo.dtssjg', {topic : $scope.keyWord}, {reload : true});
    由于html中无法动态绑定ui-sref中的路径,可以在控制器中通过state来做跳转
路由中的其他配额
    templateProvider:返回HTML字符串的函数
    $stateProvider.state(‘blog.detail', {
    templateProvider: function ($timeout, $stateParams) {
      return $timeout(function () {
        return '<h1>' + $stateParams.blogID + '</h1>'
      }, 100);
    }
  })
  //以下几个项目中并没有进行配置,而是将功能分化到对控制器和指令中,具体功能也不太理解。可参照官方文档:https://github.com/angular-ui/ui-router/wiki
  controller、controllerProvider:指定任何已经被注册的控制器或者一个作为控制器的函数 
  resolve:在路由到达前预载入一系列依赖或者数据,然后注入到控制器中。 
  data:数据不会被注入到控制器中,用途是从父状态传递数据到子状态。 
  onEnter/onExit:进入或者离开当前状态的视图时会调用这两个函数 
关于angulsrjs入门介绍,可参阅这篇博文:http://www.zouyesheng.com/angular.html#toc66
												
											ui-router的使用的更多相关文章
- 【原创】ui.router源码解析
		
Angular系列文章之angular路由 路由(route),几乎所有的MVC(VM)框架都应该具有的特性,因为它是前端构建单页面应用(SPA)必不可少的组成部分. 那么,对于angular而言,它 ...
 - angular : $location & $state(UI router)的关系
		
次序:angular 的 location会先跑 $rootScope.$on("$locationChangeStart", function (scope, newUrl, o ...
 - angularjs ngRoute和ui.router对比
		
ngRoute模块是angularjs自带的路由模块,ui.router是一个第三方路由模块,接下来将对两者进行一个对比: ng-router(angular-router.js) ng-view n ...
 - angular ui.router 路由传参数
		
angular已经用了一段时间了,最近在做路由,做一下笔记. 路由跳转的时候进行穿参 ui.router方式 <a ui-sref="edit({id:5})"> 编辑 ...
 - ngRoute 与ui.router区别
		
angular路由 路由 (route) ,几乎所有的 MVC(VM) 框架都应该具有的特性,因为它是前端构建单页面应用 (SPA) 必不可少的组成部分. 那么,对于 angular 而言,它自然也有 ...
 - AngularJS 使用 UI Router 实现表单向导
		
Today we will be using AngularJS and the great UI Router and the Angular ngAnimate module to create ...
 - ngRoute 和 ui.router 的使用方法和区别
		
在单页面应用中要把各个分散的视图给组织起来是通过路由机制来实现的.本文主要对 AngularJS 原生的 ngRoute 路由模块和第三方路由模块 ui.router 的用法进行简单介绍,并做一个对比 ...
 - [转]AngularJS 使用 UI Router 实现表单向导
		
本文转自:http://www.oschina.net/translate/angularjs-multi-step-form-using-ui-router 今天我们将使用AngularJs和伟大的 ...
 - [转]AngularJS+UI Router(1) 多步表单
		
本文转自:https://www.zybuluo.com/dreamapplehappy/note/54448 多步表单的实现 在线demo演示地址https://rawgit.com/dream ...
 - angularJS ui router 多视图单独刷新问题
		
场景:视图层级如下 view1 --view11 --view111 需求:view11的一个动作过后,单独刷新view12 解决方式:修改层级设计 view1 --view11 --view111 ...
 
随机推荐
- PHP数组和Json之间的互相转换  json_encode() 和 json_decode()
			
之所以要用到Json,很多时候是因为使用ajax对象时,程序与JS函数之间的数据交互.因为JS不认识PHP中的数组,PHP也不认识JS中的数组或对象.Json很好的解决了这个问题. Json简介 JS ...
 - BZOJ3188: [Coci 2011]Upit
			
3188: [Coci 2011]Upit Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 72 Solved: 24[Submit][Status] ...
 - AHOI2006文本编辑器editor
			
1269: [AHOI2006]文本编辑器editor Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1885 Solved: 683[Submit ...
 - js数组如何去掉逗号
			
技术水平比较差,有错误的地方或者大神们有好的方法在介绍下,可以指点出来我加以改正! 1.join去掉逗号',' var a = ['1', '2', '3', '4', '5']; var c = a ...
 - Silverlight的ComboBox 的绑定和取值
			
Silverlight的ComboBox与winform中的ComboBox存在类似的地方,但也有不同之处,本章包含以下内容: 一.ComboBox 如何添加和绑定数据. 二.ComboBox 如何添 ...
 - Axure RP 8.0 中继器初体验
			
为了解决增删等复杂交互的问题,中继器是个不错的选择. 拖拽出一个默认的中继器 中继器的数据集感觉就像是数据库一样,在右边检视窗口中可以看到中继器的默认数据集,可以理解成一张二维表.默认有1列,现成的3 ...
 - IoC/DIP其实是一种管理思想
			
关于IoC的的概念提出来已经很多年了,其被用于一种面象对像的设计.我在这里再简单的回顾一下这个概念.我先谈技术,再说管理. 话说,我们有一个开关要控制一个灯的开和关这两个动作,最常见也是最没有技术含量 ...
 - ASP.NET【2】
			
从上一节我们了解到ASP.NET是一种动态网页技术,在服务器端运行.Net代码,服务器端接收处理动态生成HTML代码,然后发送给浏览器,再由浏览器解析HTML代码将数据呈现给用户. 那么,下面我来介绍 ...
 - spring集成guava的event bus
			
Guava的event bus guava, https://github.com/google/guava 是一个非常有名的Java类库,提供了很多在日常开发中常用的集合.函数接口等.此外,guav ...
 - onethink对二维数组结果集进行排序
			
<?php /** * 对查询结果集进行排序 * @access public * @param array $list 查询结果 * @param string $field 排序的字段名 * ...