使用AngularJS实现可伸缩的页面切换的方法
程序员文章站
2022-06-26 19:08:32
angularjs 1.2 通过引入基于纯css class的切换和动画,在一个单页面应用创建页面到页面的切换变得更加的容易。只需要使用一个ng-view,让我们来看一下,...
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); }
下一篇: python查询sqlite数据表的方法
推荐阅读
-
Angularjs使用directive自定义指令实现attribute继承的方法详解
-
ThinkPHP框架使用redirect实现页面重定向的方法实例分析
-
使用纯php代码实现页面伪静态的方法
-
Flutter实现页面切换后保持原页面状态的3种方法
-
Android开发使用Activity嵌套多个Fragment实现横竖屏切换功能的方法
-
windows NLB+ARR实现Web负载均衡高可用/可伸缩的方法
-
AngularJS使用带属性值的ng-app指令实现自定义模块自动加载的方法
-
AngularJS实现单一页面内设置跳转路由的方法
-
HTML5实现页面切换激活的PageVisibility API使用初探
-
vue使用pdfjs显示PDF可复制的实现方法