Im working on a angular project, where i have set my states as shown below.
$stateProvider.state('UserPanel', {
url: '/user',
params: { userId: null },
views: {
'content@': {
templateUrl: '/AngViews/UserPanel/UserPanel.UserDetails.html'
}
}
});
when i navigate to the view, it takes the params with it, so this part is working.
But when i update the page, it's loses the params. I know that if i defined the params in the url variable it will work. but i want to make it invisible.
I have found something like this, but don't know if it's gonna fix my problem. can't get it working if it does. anyone who can explain how this can be done?
Thanks for your time
I faced the same problem and solved it with this code
Gist
I try to use the
localStorageService
to 'cache' the params between state transitions.when going from state A to state B , I remove the params previously stored for A.
I then check to see if the params that are being sent to B match the params in the state definition of B, and if they do match I load the params from the localStorage , because this means that the user has hit refresh and the params got reset.
I tested this code on a couple of cases , but it is still not fully tested.