使用AngularJS实现可伸缩的页面切换的方法


Posted in Javascript onJune 19, 2015

AngularJS 1.2 通过引入基于纯CSS class的切换和动画,在一个单页面应用创建页面到页面的切换变得更加的容易。只需要使用一个ng-view,让我们来看一下,一个引入众多的不同切换的可伸缩方法,以及指定的每个页面如何切入和切出。

演示: http://embed.plnkr.co/PqhvmW/preview

首先,标记:
 

<div class="page-container">
  <div ng-view class="page-view" ng-class="pageAnimationClass"> </div>
 </div>
既然ng-view使用进入/离开动画,那么就能简单地在DOM里使用两个 ng-view 元素来进行新视图切入和旧视图切出。因此,我们在使用相对定位的 page-container 元素里,使用绝对定位建立了ng-view,从而支持任意一种定位切换。

'go' 方法

在单页面应用里,我们仍想启用通过URL导航和确保浏览器的回退和下一步按钮如预期的功能。所以一旦我们在$routeProvider设好我们的路由,模板,控制器(可选的解析),我们可以在一个 ng-click 里使用一个相对路径来直接切换页面:
 

<a ng-click="/page2">Go to page 2</a>

那样也可以工作,但是我们需要在ng-view 硬编码指定切换一个class 。以此代替,让我们在 $rootScope 上创建一个 'go' 方法,可以让我们指定一个路径和一个像这样的切换:
 

<a ng-click="go('/page2', 'slideLeft')">Go to page 2</a>

这是我们 $rootScope 'go' 方法:
 

$rootScope.go = function (path, pageAnimationClass) {
 
  if (typeof(pageAnimationClass) === 'undefined') { // Use a default, your choice
    $rootScope.pageAnimationClass = 'crossFade';
  }
     
  else { // Use the specified animation
    $rootScope.pageAnimationClass = pageAnimationClass;
  }
 
  if (path === 'back') { // Allow a 'back' keyword to go to previous page
    $window.history.back();
  }
     
  else { // Go to the specified path
    $location.path(path);
  }
};

现在,任何你第二个参数指定的 切换类 将会添加到 ng-view 并且 go 方法将会用指定的第一个参数改变页面路径。

切换类

接下来要做的就是创建一个任意数量的切换类,并使用 ngAnimate module 提供的钩子,例如:
 

/* slideLeft */
.slideLeft {
  transition-timing-function: ease;
  transition-duration: 250ms;
}
 
.slideLeft.ng-enter {
  transition-property: none;
  transform: translate3d(100%,0,0);
}
 
.slideLeft.ng-enter.ng-enter-active {
  transition-property: all;
  transform: translate3d(0,0,0);
}
 
.slideLeft.ng-leave {
  transition-property: all;
  transform: translate3d(0,0,0);
}
 
.slideLeft.ng-leave.ng-leave-active {
  transition-property: all;
  transform: translate3d(-100%,0,0);
}

Javascript 相关文章推荐
非常不错的一个javascript 类
Nov 07 Javascript
提高网站信任度的技巧
Oct 17 Javascript
jQuery 事件队列调整方法
Sep 18 Javascript
基于jquery的气泡提示效果
May 31 Javascript
javascript 全选与全取消功能的实现代码
Dec 23 Javascript
JQuery的attr 与 val区别
Jun 12 Javascript
vue 如何添加全局函数或全局变量以及单页面的title设置总结
Jun 01 Javascript
JavaScript数组特性与实践应用深入详解
Dec 30 Javascript
自定义Vue组件打包、发布到npm及使用教程
May 22 Javascript
JS字符串与二进制的相互转化实例代码详解
Jun 28 Javascript
使用layui实现的左侧菜单栏以及动态操作tab项方法
Sep 10 Javascript
深入理解基于vue-cli的webpack打包优化实践及探索
Oct 14 Javascript
使用AngularJS实现表单向导的方法
Jun 19 #Javascript
举例详解AngularJS中ngShow和ngHide的使用方法
Jun 19 #Javascript
使用AngularJS和PHP的Laravel实现单页评论的方法
Jun 19 #Javascript
测试IE浏览器对JavaScript的AngularJS的兼容性
Jun 19 #Javascript
使用ngView配合AngularJS应用实现动画效果的方法
Jun 19 #Javascript
Backbone.js的Hello World程序实例
Jun 19 #Javascript
使用AngularJS处理单选框和复选框的简单方法
Jun 19 #Javascript
You might like
php防注入,表单提交值转义的实现详解
2013/06/10 PHP
js限制checkbox勾选的个数以及php获取多个checkbbox的方法深入解析
2013/07/18 PHP
php解压文件代码实现php在线解压
2014/02/13 PHP
php+flash+jQuery多图片上传源码分享
2020/07/27 PHP
PHP实现的简单对称加密与解密方法实例小结
2017/08/28 PHP
PHP对象的浅复制与深复制的实例详解
2017/10/26 PHP
thinkphp整合系列之极验滑动验证码geetest功能
2019/06/18 PHP
jquery ajax post提交数据乱码
2013/11/05 Javascript
jQuery取得select选择的文本与值的示例
2013/12/09 Javascript
深入理解javascript中concat方法
2016/12/12 Javascript
jQuery制作图片旋转效果
2017/02/02 Javascript
vue插件vue-resource的使用笔记(小结)
2017/08/04 Javascript
在Node.js下运用MQTT协议实现即时通讯及离线推送的方法
2019/01/24 Javascript
详解iframe跨域的几种常用方法(小结)
2019/04/29 Javascript
微信小程序点击滚动到指定位置的实现
2020/05/22 Javascript
微信小程序开发(一):服务器获取数据列表渲染操作示例
2020/06/01 Javascript
在vue项目中引用Antv G2,以饼图为例讲解
2020/10/28 Javascript
Python找出list中最常出现元素的方法
2016/06/14 Python
python爬虫_微信公众号推送信息爬取的实例
2017/10/23 Python
django模型层(model)进行建表、查询与删除的基础教程
2017/11/21 Python
Python快速排序算法实例分析
2017/11/29 Python
Python3结合Dlib实现人脸识别和剪切
2018/01/24 Python
django使用django-apscheduler 实现定时任务的例子
2019/07/20 Python
python爬虫看看虎牙女主播中谁最“顶”步骤详解
2020/12/01 Python
手把手教你配置JupyterLab 环境的实现
2021/02/02 Python
详解CSS3中nth-child与nth-of-type的区别
2017/01/05 HTML / CSS
Html5页面上如何禁止手机虚拟键盘弹出
2020/03/19 HTML / CSS
世界上最好的足球商店:Unisport
2019/03/02 全球购物
SQL Server笔试题
2012/01/10 面试题
为什么要做架构设计
2015/07/08 面试题
法学专业个人求职信
2013/09/26 职场文书
班级安全教育实施方案
2014/02/23 职场文书
4S店收银员岗位职责
2015/04/07 职场文书
运动会开幕式新闻稿
2015/07/17 职场文书
2016年度先进班组事迹材料
2016/03/01 职场文书
聊聊CSS粘性定位sticky案例解析
2022/06/01 HTML / CSS