大佬教程收集整理的这篇文章主要介绍了angularjs ui-router stateparams页面刷新时看不见丢失,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
$stateProvider.state('UserPanel',{ url: '/user',params: { userId: null },views: { 'content@': { templateUrl: '/AngViews/UserPanel/UserPanel.UserDetails.html' } } });
当我导航到视图时,它会使用它的参数,所以这部分正在工作.@H_696_10@
但是当我更新页面时,它失去了参数.
我知道如果我在url变量中定义了参数,它将起作用.但我想让它隐形.@H_696_10@
我找到了像this这样的东西,但不知道它是否能解决我的问题.如果确实如此,它就无法运作.有谁可以解释如何做到这一点?@H_696_10@
angular.module('app').run(function($rootScope,$state,localStorageservicE) { $rootScope.$on('$stateChangeStart',function(event,toState,toParams,fromState,fromParams) { var prefix = "stateParams."; var fromStatename = prefix + fromState.name; var toStatename = prefix + toState.name; var f = true; for (var k in toState.params) { f = f && (JSON.@R_262_10495@ngify(toParams[k]) == JSON.@R_262_10495@ngify(toState.params[k])); } if (f && localStorageservice.get(toStateName) != null) { event.preventDefault(); var savedToParams = localStorageservice.get(toStateName); //retrieving toParams from local storage localStorageservice.remove(toStateName); for (var k in toState.params) { toParams[k] = savedToParams[k]; //update only the params {} not url params } $state.transitionTo(toState,toParams); } else { var toSave = {}; for (var k in toState.params) { toSave[k] = toParams[k]; //save only the params {} not url params } localStorageservice.set(toStatename,toSavE); } }); });
我尝试使用localStorageservice来“缓存”状态转换之间的参数.@H_696_10@
当从状态A进入状态B时,我删除先前为A存储的参数.@H_696_10@
然后我检查发送到B的params是否与B的状态定义中的params匹配,如果它们匹配,我从localStorage加载params,因为这意味着用户已经点击刷新并且params得到了重启.@H_696_10@
以上是大佬教程为你收集整理的angularjs ui-router stateparams页面刷新时看不见丢失全部内容,希望文章能够帮你解决angularjs ui-router stateparams页面刷新时看不见丢失所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。