国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 12:12:24
字體:
來源:轉載
供稿:網友

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);}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 景德镇市| 海安县| 托克托县| 余干县| 商城县| 连云港市| 阿克陶县| 弥渡县| 夹江县| 宝清县| 土默特右旗| 九龙坡区| 安平县| 兖州市| 平果县| 晋江市| 光泽县| 牡丹江市| 鹰潭市| 房产| 梨树县| 浪卡子县| 绥阳县| 奎屯市| 恩施市| 德保县| 张家界市| 札达县| 白河县| 萨迦县| 社旗县| 汕头市| 榆树市| 栾城县| 阿拉尔市| 剑阁县| 即墨市| 南川市| 炉霍县| 江口县| 泽普县|