Я использую Angular UI Router, и когда я нажимаю на любую опцию в navbar, он загружает соответствующее состояние в дочерний режим. Но проблема в том, что всякий раз, когда я нажимаю на любой элемент списка в navbar, он также загружает родительский и перезагружает навигационную панель по умолчанию. Как решить эту проблему, всякий раз, когда я нажимаю на любой из этих элементов навигационной системы, он загружает соответствующее состояние в дочернее представление, но никогда не перезапускает родительский.Загружать дочерние состояния без обновления родительского состояния в AngularJS
Проверьте этот gif чтобы узнать о проблеме.
Это мой config
блок в app.js
// Routes defined in config
app.config(function($stateProvider, $urlRouterProvider) {
$urlRouterProvider.otherwise('/dashboard');
$stateProvider
// Home route
.state('dashboard', {
url: '/dashboard',
views: {
'': {
templateUrl: 'views/dashboard.html' ,
controller : 'mainCtrl'
},
'[email protected]': {
templateUrl: 'views/home.html',
controller: 'homeController'
}
}
})
//login route
.state('login',{
url: '/login',
templateUrl: 'views/login.html',
controller: 'authController'
})
.state('logout',{
controller:'logout'
})
//Add role
.state('addRole',{
url: '/addRole',
views: {
'': {
templateUrl: 'views/dashboard.html' ,
controller : 'mainCtrl'
},
'[email protected]': {
templateUrl: 'views/addRole.html',
controller: 'addRole'
}
}
})
//Add role
.state('getUserInfoData',{
url: '/getUserInfoData',
views: {
'': {
templateUrl: 'views/dashboard.html' ,
controller : 'mainCtrl'
},
'[email protected]': {
templateUrl: 'views/getUserInfoData.html',
controller: 'getUserInfoData'
}
}
})
//manage role
.state('manageRole',{
url: '/manageRole',
views: {
'': {
templateUrl: 'views/dashboard.html' ,
controller : 'mainCtrl'
},
'[email protected]': {
templateUrl: 'views/manageRole.html',
controller: 'manageRole'
}
}
})
.state('manageUsers',{
url: '/manageUsers',
views: {
'': {
templateUrl: 'views/dashboard.html',
controller : 'mainCtrl'
},
'[email protected]': {
templateUrl: 'views/manageUsers.html',
controller: 'manageUsers'
}
}
})
.state('sendSms',{
url: '/sendSms',
views: {
'': {
templateUrl: 'views/dashboard.html',
controller : 'mainCtrl'
},
'[email protected]': {
templateUrl: 'views/sendSms.html',
controller : 'smsController'
}
}
})
//Manage Import/Export CSV
.state('manageCsv',{
url: '/manageCsv',
views: {
'': {
templateUrl: 'views/dashboard.html' ,
controller : 'mainCtrl'
},
'[email protected]': {
templateUrl: 'views/manageCsv.html',
controller: 'manageCsv'
}
}
})
// Check user Route
.state('checkUser', {
url: '/',
controller: 'checkController'
})
// List All Claim
.state('createForm', {
url: '/createForm',
views: {
'': {
templateUrl: 'views/dashboard.html' ,
controller : 'mainCtrl'
},
'[email protected]': {
templateUrl:'views/createForm.html',
controller: 'createForm'
}
}
})
//list claim profile
.state('claimProfile', {
url: '/claimProfile/:id',
views: {
'': {
templateUrl: 'views/dashboard.html' ,
controller : 'mainCtrl'
},
'[email protected]': {
templateUrl:'views/claimProfile.html',
controller: 'claimProfile'
}
}
})
//list all forms
.state('manageForms', {
url: '/manageForms',
views: {
'': {
templateUrl: 'views/dashboard.html' ,
controller : 'mainCtrl'
},
'[email protected]': {
templateUrl:'views/manageForms.html',
controller: 'manageForms'
}
}
});
});
Это мой HTML
<div class="left-sidebar-section">
<div class="section-title">Claims</div>
<ul class="list-unstyled" id="form-components">
<li ui-sref="getUserInfoData">
<button class="btn btn-flat" data-parent="#form-components" ng-class="{activeMenu : isActive('/getUserInfoData')}">
<span class="btn-title">
<a>Users Data</a>
</span>
<i class="material-icons pull-left icon">folder</i>
</button>
</li>
</ul>
</div>
Thankyou очень много .. это решить мою проблему, но когда я поставил 'аннотация: правда,' это показывает ошибку. В любом случае, когда я не ставил его, код работает нормально. ':)' я не знаю почему, но это работает .. thankyou @yBrodsky – gauravmehla