首頁 > web前端 > js教程 > 使用AngularJS實作可伸縮的頁面切換的方法_AngularJS

使用AngularJS實作可伸縮的頁面切換的方法_AngularJS

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-05-16 15:53:41
原創
1176 人瀏覽過

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);
}
登入後複製


相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
JavaScript鉤子函數是什麼?
來自於 1970-01-01 08:00:00
0
0
0
怎麼實作 JavaScript點與圓的位置關係
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板