vue-router實(shí)現(xiàn)webApp切換頁面動(dòng)畫效果代碼
vue-router實(shí)現(xiàn)webApp切換效果
演示效果

快速集成
1.復(fù)制PageTransittion.vue到項(xiàng)目目錄。2.修改router配置。
Router.prototype.goBack = function () {
this.isBack = true
window.history.go(-1)
}
const router = new Router({
routes: [
{
path: '/',
name: 'PageTransition',
component: PageTransition, // 引入頁面切換組件
children: [{
path: '',
component: Index // 父路由訪問頁面,例如,訪問www.aaa.com/ 顯示的是Index組件
}, {
path: '/pageA',
component: PageA // 子路由組件 例如,訪問www.aaa.com/pageA 顯示為PageA
}, {
path: '/pageB',
component: PageB // 子路由組件 例如,訪問www.aaa.com/pageB 顯示為PageB
}]
}
]
})
方案實(shí)現(xiàn)
記錄頁面狀態(tài)
要實(shí)現(xiàn)頁面前進(jìn)后臺(tái)動(dòng)畫,首先必須知道頁面狀態(tài)(即是頁面是進(jìn)入下一頁,還是后退),我們可以通過改寫router.Go方法記錄回退狀態(tài),頁面如果需要回退時(shí),調(diào)用
$router.go(-1)
修改router/index.vue
// 增強(qiáng)原方法,好處是舊的業(yè)務(wù)模塊不需要任何變動(dòng)
Router.prototype.go = function () {
this.isBack = true
window.history.go(-1)
}
// 或者你可以新建一個(gè)方法
Router.prototype.goBack = function () {
this.isBack = true
this.go(-1)
}
當(dāng)new Router時(shí),實(shí)例就包含go/goBack方法。
監(jiān)聽路由變化
使用嵌套路由的方式引入子頁面,監(jiān)聽根路由的update鉤子做相應(yīng)操作。
beforeRouteUpdate (to, from, next) {
// 如果isBack為true時(shí),證明是用戶點(diǎn)擊了回退,執(zhí)行slide-right動(dòng)畫
let isBack = this.$router.isBack
if (isBack) {
this.transitionName = 'slide-right'
} else {
this.transitionName = 'slide-left'
}
// 做完回退動(dòng)畫后,要設(shè)置成前進(jìn)動(dòng)畫,否則下次打開頁面動(dòng)畫將還是回退
this.$router.isBack = false
next()
}
動(dòng)畫效果
通過transition執(zhí)行動(dòng)畫
<transition :name="transitionName"> <router-view class="child-view"></router-view> </transition>
css代碼
.child-view {
position: absolute;
width:100%;
transition: all .8s cubic-bezier(.55,0,.1,1);
}
.slide-left-enter, .slide-right-leave-active {
opacity: 0;
-webkit-transform: translate(50px, 0);
transform: translate(50px, 0);
}
.slide-left-leave-active, .slide-right-enter {
opacity: 0;
-webkit-transform: translate(-50px, 0);
transform: translate(-50px, 0);
}
路由設(shè)置
router/index.js
const router = new Router({
routes: [
{
path: '/',
name: 'PageTransition',
component: PageTransition,
children: [{
// 該路由為父路由的默認(rèn)路由
path: '',
component: Index
}, {
path: '/pageA',
component: PageA
}, {
path: '/pageB',
component: PageB
}]
}
]
})
github地址:https://github.com/zhengguorong/pageAinimate
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- vue中使用vue-router切換頁面時(shí)滾動(dòng)條自動(dòng)滾動(dòng)到頂部的方法
- 詳解使用vue-router進(jìn)行頁面切換時(shí)滾動(dòng)條位置與滾動(dòng)監(jiān)聽事件
- vue實(shí)現(xiàn)app頁面切換動(dòng)畫效果實(shí)例
- Vue 路由切換時(shí)頁面內(nèi)容沒有重新加載的解決方法
- 基于Vue實(shí)現(xiàn)頁面切換左右滑動(dòng)效果
- 使用vue-router切換頁面時(shí),獲取上一頁url以及當(dāng)前頁面url的方法
- vue 路由頁面之間實(shí)現(xiàn)用手指進(jìn)行滑動(dòng)的方法
- vue中選項(xiàng)卡點(diǎn)擊切換且能滑動(dòng)切換功能的實(shí)現(xiàn)代碼
- vue實(shí)現(xiàn)滑動(dòng)切換效果(僅在手機(jī)模式下可用)
- vue實(shí)現(xiàn)頁面切換滑動(dòng)效果
相關(guān)文章
使用vue.js實(shí)現(xiàn)checkbox的全選和多個(gè)的刪除功能
這篇文章主要介紹了使用vue.js實(shí)現(xiàn)checkbox的全選和多個(gè)的刪除功能,需要的朋友可以參考下2017-02-02
一篇文章帶你吃透Vue生命周期(結(jié)合案例通俗易懂)
這篇文章主要給大家介紹了關(guān)于如何通過一篇文章帶你吃透Vue生命周期,文章通過結(jié)合案例更加的通俗易懂,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-02-02
Vue2實(shí)現(xiàn)txt文件在線預(yù)覽的代碼示例
txt文件在線預(yù)覽不需要下載另外的插件,主要有兩種形式,一種是上傳完成后實(shí)現(xiàn)預(yù)覽;另一種是后端提供文件下載接口,獲取文件在線地址實(shí)現(xiàn)預(yù)覽;本文給大家介紹了Vue2實(shí)現(xiàn)txt文件在線預(yù)覽的代碼示例,需要的朋友可以參考下2025-01-01
Vue 多選框所選數(shù)量動(dòng)態(tài)變換Box的高度
在Web開發(fā)中,使用Vue.js框架可以通過ref屬性、v-model指令和計(jì)算屬性等特性實(shí)現(xiàn)元素高度的動(dòng)態(tài)調(diào)整,文章詳細(xì)介紹了如何利用Vue的功能根據(jù)多選框的選擇數(shù)量動(dòng)態(tài)改變?cè)氐母叨?并通過多個(gè)示例展示其應(yīng)用2024-09-09
Vue 2.0 中依賴注入 provide/inject組合實(shí)戰(zhàn)
這篇文章主要介紹了Vue 2.0 依賴注入 provide/inject組合,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-06-06
Vue?中的?computed?和?watch?的區(qū)別詳解
這篇文章主要介紹了Vue中的computed和watch的區(qū)別詳解,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09
vue?Element?UI擴(kuò)展內(nèi)容過長(zhǎng)使用tooltip顯示
這篇文章主要為大家介紹了vue?Element?UI擴(kuò)展內(nèi)容過長(zhǎng)使用tooltip展示鼠標(biāo)hover時(shí)的提示信息,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06

