AngularJS的ui-router第一次点击激活路由加载页面,再次点击就没用,如何实现每次点击都激活加载路由一次

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了AngularJS的ui-router第一次点击激活路由加载页面,再次点击就没用,如何实现每次点击都激活加载路由一次相关的知识,希望对你有一定的参考价值。

angularJS的UI-Router只有第一次点击才激活路由加载页面,再次点击就没用了,怎么实现每次点击都激活加载路由一次。比如我第一次点击了一个菜单项,激活此路由了,在页面中部嵌入路由的页面,,再次点击的时候就不动了,,页面不刷新了, 我想再次点击的时候重新激活加载路由一次,以实现点击一次刷新一次重新激活路由达到刷新效果

参考技术A 为链接加上reload属性
<a ui-sref="xxxx" ui-sref-opt="reload:true">xxxx</a>
大概是这样,记不太清了.你可以去官网查一下api本回答被提问者和网友采纳
参考技术B 不会啊,每次点击都会跳转的啊,是不是你的代码有问题

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>

 



以上是关于AngularJS的ui-router第一次点击激活路由加载页面,再次点击就没用,如何实现每次点击都激活加载路由一次的主要内容,如果未能解决你的问题,请参考以下文章

AngularJS ui-router (嵌套路由)

AngularJS ui-router 登录认证

Angularjs UI-route 为啥无法跳转到 test.html

AngularJS的UI-Router学习

AngularJS的UI-Router学习

如何使用 AngularJS 的 ui-router 提取查询参数?