我在角度應用中使用角度ui路由器。對於路由部分,我已經寫了角度ui路由器加載視圖兩次
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.'
})
});
在部分home.html的我wriiten: -
<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時),控制檯會顯示兩次。請幫助我爲什麼會發生這種事情。
由於列表是家庭的孩子,那麼它顯然會首先加載視圖,然後是視圖列表。但這裏的家庭觀點正在被加載兩次。我沒有添加任何控制檯列表viewContentLoaded。另一件事是,當我在/ home並點擊列表鏈接時,同樣的事情也會發生。但在那種情況下,它只顯示一個控制檯。 – Indra
我想你使用ui-view在家庭模板中導致孩子和父母共享相同的範圍。你正在傾聽孩子和家長的事件範圍。所以被調用兩次是很自然的 – bahadir
我也爲列表定義了一個控制器,所以它沒有得到相同的範圍。同樣的事情正在發生。 – Indra