使用AngularJS實現(xiàn)可伸縮的頁面切換的方法
AngularJS 1.2 通過引入基于純CSS class的切換和動畫,在一個單頁面應(yīng)用創(chuàng)建頁面到頁面的切換變得更加的容易。只需要使用一個ng-view,讓我們來看一下,一個引入眾多的不同切換的可伸縮方法,以及指定的每個頁面如何切入和切出。
演示: http://embed.plnkr.co/PqhvmW/preview
首先,標記:
<div class="page-container"> <div ng-view class="page-view" ng-class="pageAnimationClass"> </div> </div>
'go' 方法
在單頁面應(yīng)用里,我們?nèi)韵雴⒂猛ㄟ^URL導(dǎo)航和確保瀏覽器的回退和下一步按鈕如預(yù)期的功能。所以一旦我們在$routeProvider設(shè)好我們的路由,模板,控制器(可選的解析),我們可以在一個 ng-click 里使用一個相對路徑來直接切換頁面:
<a ng-click="/page2">Go to page 2</a>
那樣也可以工作,但是我們需要在ng-view 硬編碼指定切換一個class 。以此代替,讓我們在 $rootScope 上創(chuàng)建一個 '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); } };
現(xiàn)在,任何你第二個參數(shù)指定的 切換類 將會添加到 ng-view 并且 go 方法將會用指定的第一個參數(shù)改變頁面路徑。
切換類
接下來要做的就是創(chuàng)建一個任意數(shù)量的切換類,并使用 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); }
相關(guān)文章
angular 實現(xiàn)的輸入框數(shù)字千分位及保留幾位小數(shù)點功能示例
這篇文章主要介紹了angular 實現(xiàn)的輸入框數(shù)字千分位及保留幾位小數(shù)點功能,涉及AngularJS數(shù)值運算、正則匹配等相關(guān)操作技巧,需要的朋友可以參考下2018-06-06詳解封裝基礎(chǔ)的angular4的request請求方法
這篇文章主要介紹了詳解封裝基礎(chǔ)的angular4的request請求方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06angular框架實現(xiàn)全選與單選chekbox的自定義
這篇文章主要介紹了angular框架實現(xiàn)全選與單選chekbox的自定義,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07AngularJS實現(xiàn)select的ng-options功能示例
這篇文章主要介紹了AngularJS實現(xiàn)select的ng-options功能,結(jié)合實例形式分析了AngularJS使用ng-options操作select列表的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2017-07-07Angular2從搭建環(huán)境到開發(fā)步驟詳解
本文的內(nèi)容主要是想幫助那些想學(xué)習(xí)Angular2的朋友們,因為我自己在玩Angular2時碰到了不少坑,而且Angular2語法一直處于變化中,讓人很頭疼。不過也怪不了Anguar2,因為它現(xiàn)在是處于并長期處于alpha階段,下面就通過本文來學(xué)習(xí)Angular2的搭建環(huán)境和開發(fā)吧。2016-10-10