使用AngularJS實(shí)現(xiàn)可伸縮的頁(yè)面切換的方法
AngularJS 1.2 通過(guò)引入基于純CSS class的切換和動(dòng)畫(huà),在一個(gè)單頁(yè)面應(yīng)用創(chuàng)建頁(yè)面到頁(yè)面的切換變得更加的容易。只需要使用一個(gè)ng-view,讓我們來(lái)看一下,一個(gè)引入眾多的不同切換的可伸縮方法,以及指定的每個(gè)頁(yè)面如何切入和切出。
演示: http://embed.plnkr.co/PqhvmW/preview
首先,標(biāo)記:
<div class="page-container"> <div ng-view class="page-view" ng-class="pageAnimationClass"> </div> </div>
'go' 方法
在單頁(yè)面應(yīng)用里,我們?nèi)韵雴⒂猛ㄟ^(guò)URL導(dǎo)航和確保瀏覽器的回退和下一步按鈕如預(yù)期的功能。所以一旦我們?cè)?routeProvider設(shè)好我們的路由,模板,控制器(可選的解析),我們可以在一個(gè) ng-click 里使用一個(gè)相對(duì)路徑來(lái)直接切換頁(yè)面:
<a ng-click="/page2">Go to page 2</a>
那樣也可以工作,但是我們需要在ng-view 硬編碼指定切換一個(gè)class 。以此代替,讓我們?cè)?$rootScope 上創(chuàng)建一個(gè) 'go' 方法,可以讓我們指定一個(gè)路徑和一個(gè)像這樣的切換:
<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)在,任何你第二個(gè)參數(shù)指定的 切換類(lèi) 將會(huì)添加到 ng-view 并且 go 方法將會(huì)用指定的第一個(gè)參數(shù)改變頁(yè)面路徑。
切換類(lèi)
接下來(lái)要做的就是創(chuàng)建一個(gè)任意數(shù)量的切換類(lèi),并使用 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);
}
- JS代碼實(shí)現(xiàn)頁(yè)面切換效果
- 基于JS實(shí)現(xiàn)翻書(shū)效果的頁(yè)面切換樣式
- 簡(jiǎn)單實(shí)現(xiàn)js頁(yè)面切換功能
- javaScript實(shí)現(xiàn)鼠標(biāo)在文字上懸浮時(shí)彈出懸浮層效果
- js 文字超出長(zhǎng)度用省略號(hào)代替,鼠標(biāo)懸停并以懸浮框顯示實(shí)例
- javascript 鼠標(biāo)懸浮圖片顯示原圖 移出鼠標(biāo)后原圖消失(多圖)
- Vue.js鼠標(biāo)懸浮更換圖片功能
- js制作的鼠標(biāo)懸浮時(shí)產(chǎn)生的下拉框效果
- js鼠標(biāo)懸浮出現(xiàn)遮罩層的方法
- JavaScript實(shí)現(xiàn)鼠標(biāo)懸浮頁(yè)面切換效果
相關(guān)文章
Angular6使用forRoot() 注冊(cè)單一實(shí)例服務(wù)問(wèn)題
這篇文章主要介紹了Angular6使用forRoot() 注冊(cè)單一實(shí)例服務(wù)問(wèn)題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08
angularjs 表單密碼驗(yàn)證自定義指令實(shí)現(xiàn)代碼
這篇文章主要介紹了angularjs 表單密碼驗(yàn)證自定義指令實(shí)現(xiàn)代碼,需要的朋友可以參考下2016-10-10
AngularJS入門(mén)教程之表單校驗(yàn)用法示例
AngularJS中取消對(duì)HTML片段轉(zhuǎn)義的方法例子
AngularJs學(xué)習(xí)第八篇 過(guò)濾器filter創(chuàng)建

