使用Angular缓存父页面数据的方法


Posted in Javascript onJanuary 03, 2017

angular做单页面应用是一个比较好的框架,但是它有一定的入门难度,对于新手来说可能会碰到很多坑,也有许多难题,大部分仔细看文档,找社区是能解决的。

但有些问题也许资料比较少,最近遇到过一个要缓存父页面的问题,就是点击进入子页后,再返回时父页面的数据要缓存下来,包括滚动条的位置。再做的过程当中查过

许多资料,都说的不很详细,今天把方法记录下来,供参考。

要想缓存,要用到嵌套路由(ui-router):

   有三个嵌套的方法:

  1. 使用“点标记法”,例如:.state('contacts.list', {})
  2. 使用parent属性,指定一个父状态的名称字符串,例如:parent: 'contacts'
  3. 使用parent属性,指定一个父状态对象,例如:parent: contacts(contacts 是一个状态对象

嵌套路由如有不明白的,大家可以自己去google下。

1.在路由中配置好后,在父页面中设置一个子view.

路由配置:

$stateProvider
 .state('parent', {})
 .state('parent.sub',{
  url: '/flightStatus/:time',
  views:{
   'subView':{
    templateUrl: 'sub.html',
    controller: ''
   }
  }
 }
);

2.配置好后,在父页面添加view和名字(如果只有一个ui-view,名字可以不要)

parent.html

<ui-view name="subView"></ui-view>
<!--其它html代码-->
……

3.这时由父页面进去后,子页面sub.html会加载到name为subView中

   在子页面中返回时,用angular的$window.history.back();

  注意:这里返回时父页面的controller将不在执行

进行以上配置后就可以缓存到父页面的数据了,返回时不会刷新,在进入子页面时大家最好把父页面隐藏(不隐藏是把内容高度设为100%),返回时再显示,这样避免子父页面都有输入框下,按下tab时会把父页面显示的bug

以上所述是小编给大家介绍的使用Angular缓存父页面数据的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持

Javascript 相关文章推荐
经典的解除许多网站无法复制文字的绝招
Dec 31 Javascript
jQuery(1.3.2) 7行代码搞定跟随屏幕滚动的层
May 21 Javascript
jquery 文本上下无缝滚动,鼠标放上去就停止 小例子
Jun 05 Javascript
javascript:void(0)的作用示例介绍
Oct 28 Javascript
jQuery.extend 函数及用法详细
Sep 06 Javascript
jQuery AjaxUpload 上传图片代码
Feb 02 Javascript
Three.js学习之Lamber材质和Phong材质
Aug 04 Javascript
JavaScript随机生成颜色的方法
Oct 15 Javascript
vue.js 使用v-if v-else发现没有执行解决办法
May 15 Javascript
JQuery Ajax 异步操作之动态添加节点功能
May 24 jQuery
浅谈Webpack自动化构建实践指南
Dec 18 Javascript
JavaScript 面向对象基础简单示例
Oct 02 Javascript
JS实现简单的二元方程计算器功能示例
Jan 03 #Javascript
JS基于递归算法实现1,2,3,4,5,6,7,8,9倒序放入数组中的方法
Jan 03 #Javascript
javascript使用递归算法求两个数字组合功能示例
Jan 03 #Javascript
jQuery仿写百度百科的目录树
Jan 03 #Javascript
通过BootStrap-select插件 js jQuery控制select属性变化
Jan 03 #Javascript
Vue.js系列之vue-router(上)(3)
Jan 03 #Javascript
JavaScript实现自定义媒体播放器方法介绍
Jan 03 #Javascript
You might like
用PHP实现Ftp用户的在线管理
2012/02/16 PHP
一份老外写的XMLHttpRequest代码多浏览器支持兼容性
2007/01/11 Javascript
JavaScript 以对象为索引的关联数组
2010/05/19 Javascript
浅析document.createDocumentFragment()与js效率
2013/07/08 Javascript
详解jQuery插件开发中的extend方法
2013/11/19 Javascript
JavaScript控制两个列表框listbox左右交换数据的方法
2015/03/18 Javascript
每天一篇javascript学习小结(RegExp对象)
2015/11/17 Javascript
浅谈JavaScript中小数和大整数的精度丢失
2016/05/31 Javascript
jquery中用jsonp实现搜索框功能
2016/10/18 Javascript
详解jquery easyui之datagrid使用参考
2016/12/05 Javascript
微信小程序学习(4)-系统配置app.json详解
2017/01/12 Javascript
AngularJS表格样式简单设置方法示例
2017/03/03 Javascript
纯JS单页面赛车游戏制作代码分享
2017/03/03 Javascript
vue-resourse将json数据输出实例
2017/03/08 Javascript
JS 实现获取验证码 倒计时功能
2018/10/29 Javascript
layer.open 子页面弹出层向父页面传输数据的例子
2019/09/26 Javascript
Python中os和shutil模块实用方法集锦
2014/05/13 Python
详解Python中expandtabs()方法的使用
2015/05/18 Python
python xml解析实例详解
2016/11/14 Python
python画图把时间作为横坐标的方法
2019/07/07 Python
布隆过滤器的概述及Python实现方法
2019/12/08 Python
pycharm通过anaconda安装pyqt5的教程
2020/03/24 Python
Python用类实现扑克牌发牌的示例代码
2020/06/01 Python
HTML5单页面手势滑屏切换原理分析
2017/07/10 HTML / CSS
HTML5中的拖放实现详解
2017/08/23 HTML / CSS
美国时尚假发购物网站:Wigsbuy
2019/04/06 全球购物
阿联酋手表和配饰购物网站:Rivolishop
2019/11/25 全球购物
研究生自我鉴定范文
2013/10/30 职场文书
销售总监岗位职责
2014/01/04 职场文书
服装创业计划书范文
2014/02/05 职场文书
副科竞争上岗演讲稿
2014/05/12 职场文书
公开承诺书格式
2014/05/21 职场文书
外联部演讲稿
2014/05/24 职场文书
支部书记四风问题自我剖析材料
2014/09/29 职场文书
微信搭讪开场白
2015/05/28 职场文书
python 提取html文本的方法
2021/05/20 Python