zoukankan      html  css  js  c++  java
  • angularjs ui-router 路由简介

    ui-router 是angular的第3方路由。他与ngrouter 没有太大区别。

    ui-router 可以深度嵌套

    ngrouter 简单的嵌套,针对于单个视图(视图就是需要嵌套的页面)

    例如:我们点击了一个链接,我们需要在视图中跳转到指定的一个页面,那么ngRoute已经满足了我们的需求,而当我们点击的时候,需要在分别在不同的地方跳转两个不同的页面的时候,ngRoute就不够用了,我们就需要用到ui-router

    $urlRouterProvider

    $urlRouterProvider负责监听$location.当$location变化的时候,$urlRouterProvider开始在一个规则的列表中一个个的查找,直到找到匹配的值。

    $urlRouterProvider用于在后端指定url的状态配置。

    所有的url被编译成UrlMatcher对象。

    otherwise

    定义一个当请求的路径是无效路径时跳转的路径,或者首次加载的时候加载指定路径

     $urlRouterProvider.otherwise('/home');

    以下是一个简单的demo

     <script type="text/javascript">
          var myapp=angular.module('route',["ui.router"]);
          myapp.controller('myctr',function($scope){
             $scope.isActive = true; 
            // $scope.togg = function($event) {  
             
            //   console.log(value)  
            //   if ($event) {  
            //     $($event.target).addClass("active");  
            //   } else {  
            //     $($event.target).removeClass("active");  
            //   }  
            // }  
    
          })
          myapp.config(function($stateProvider,$urlRouterProvider){
            $urlRouterProvider.otherwise('/home');
            $stateProvider
              .state('home',{
                url:'/home',
                templateUrl:'html/home.html'
              })
              .state('home01',{
                url:'/home01',
                templateUrl:'html/home01.html'
              })
              .state('home01.list',{
                url:'/list',
                templateUrl:'html/table.html'
              })
              .state('home01.pan',{
                url:'/pan',
                templateUrl:'html/panel.html'
              })
          })
    
      </script>
    </head>
    <body>
    <div ng-app='route'>
    <nav class="navbar navbar-default" ng-controller='myctr'>
      <div class="container">
        <ul class="nav navbar-nav">
            <li ng-class="{true: ' active', false: ''}[isActive]" ng-click='isActive=true'><a ui-sref="home">Home</a></li>
           
            <li ng-class="{true: ' ', false: ' active'}[isActive]" ng-click='isActive=false'><a ui-sref="home01">Link</a></li>
        </ul>
      </div>
    </nav>
    <!-- 切换的内容显示 -->
    <div ui-view style='padding:20px;overflow:hidden'></div>
    </div>
  • 相关阅读:
    LaZagne — 一键抓取目标机器上的所有明文密码,todo,自己手动试试效果
    jsch文件复制(拷贝)
    使用Apache commons-pool2实现高效的FTPClient连接池的方法
    室内定位会议和期刊(2020-2021)
    Axure RP 9.0 Team Edition
    新电脑 windows 10 登录 执行此操作需要Internet
    maven配置,以及项目 Dependency xxxx not found 解决过程
    MySQL 下载网站
    Tomcat8.5和Tomcat9安装SSL证书的教程
    Python id() 函数
  • 原文地址:https://www.cnblogs.com/songrimin/p/6547773.html
Copyright © 2011-2022 走看看