Angular ui-router加载视图两次

时间:2014-12-23 13:51:25

标签: javascript angularjs angular-ui-router url-routing

我在角度应用程序中使用角度ui-router。对于我编写的路由部分

var routerApp = angular.module('routerApp', ['ui.router']);

routerApp.config(function($stateProvider, $urlRouterProvider) {

$urlRouterProvider.otherwise('/home');

$stateProvider

    // HOME STATES AND NESTED VIEWS ========================================
    .state('home', {
        url: '/home',
        templateUrl: 'partial-home.html',
           controller : function($scope,$state){
            $scope.$on('$viewContentLoaded', function(){
              console.log("home content loaded",$state.current);
            })
          }
    })

    // nested list with custom controller
    .state('home.list', {
        url: '/list',
        template: 'I am using a list.'
    })

    // nested list with just some random string data
    .state('home.paragraph', {
        url: '/paragraph',
        template: 'I could sure use a drink right now.'
    }) 

});

在partial-home.html中,我已经知道了: -

<div class="jumbotron text-center">
  <h1>The Homey Page</h1>
  <p>This page demonstrates <span class="text-danger">nested</span> views.</p>

  <a ui-sref=".list" class="btn btn-primary">List</a>
  <a ui-sref=".paragraph" class="btn btn-danger">Paragraph</a>

</div>

<div ui-view></div>

现在,当我在浏览器中执行此应用程序时,如果我打开路径

/home

浏览器控制台显示“加载主页内容”一次,然后如果单击列表链接,地址栏将变为

/home/list

然后控制台也会显示一次。

但是如果我在那时刷新浏览器选项卡(当路由是home / list时),则控制台会显示两次。请帮我解释为什么会发生这件事。

2 个答案:

答案 0 :(得分:2)

这些是嵌套视图。重新加载后控制台中有两条消息的原因是: 当您从/ home开始时,将加载主状态。当你去那里的/ home / list时,只需要加载home.list,因为已经加载了home状态。重新加载时,需要加载两个状态:home和home.list。

编辑:我没有足够的声誉所以我不能发表评论。我猜你在家庭模板中使用ui-view导致孩子和父母共享相同的范围。你正在听孩子和父母的活动范围。所以被叫两次是很自然的

答案 1 :(得分:1)

因为home.list是home的子状态,当你为home.list重新加载页面时 它首先初始化家庭控制器的视图而不是列表控制器的视图,因此$ viewContentLoaded被调用两次

我猜你在家庭模板中使用ui-view导致子和父共享相同的范围。你正在听孩子和父母的活动范围。所以被叫两次是很自然的