Angular UI Routerを使用しています。ナビゲーションバーの任意のオプションをクリックすると、対応する状態が子ビューにロードされます。しかし、問題は、ナビゲーションバーのリスト項目のいずれかをクリックするたびに、親項目もロードされ、ナビゲーションバーがデフォルトにリセットされることです。 この問題を解決するには、このナビゲーションバーアイテムのいずれかをクリックするたびに、子ビューに対応する状態をロードしますが、親ビューをリセットすることはありません。AngularJSで親状態を更新せずに子状態をロード
問題を理解するには、このgifを確認してください。
これは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'
}
}
});
});
これはあなたの意見を入れ子にする必要があることを行うには
<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 @yBrodsky – gauravmehla