vue-router實(shí)現(xiàn)webApp切換頁(yè)面動(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, // 引入頁(yè)面切換組件 children: [{ path: '', component: Index // 父路由訪問頁(yè)面,例如,訪問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)
記錄頁(yè)面狀態(tài)
要實(shí)現(xiàn)頁(yè)面前進(jìn)后臺(tái)動(dòng)畫,首先必須知道頁(yè)面狀態(tài)(即是頁(yè)面是進(jìn)入下一頁(yè),還是后退),我們可以通過改寫router.Go方法記錄回退狀態(tài),頁(yè)面如果需要回退時(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)聽路由變化
使用嵌套路由的方式引入子頁(yè)面,監(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)畫,否則下次打開頁(yè)面動(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切換頁(yè)面時(shí)滾動(dòng)條自動(dòng)滾動(dòng)到頂部的方法
- 詳解使用vue-router進(jìn)行頁(yè)面切換時(shí)滾動(dòng)條位置與滾動(dòng)監(jiān)聽事件
- vue實(shí)現(xiàn)app頁(yè)面切換動(dòng)畫效果實(shí)例
- Vue 路由切換時(shí)頁(yè)面內(nèi)容沒有重新加載的解決方法
- 基于Vue實(shí)現(xiàn)頁(yè)面切換左右滑動(dòng)效果
- 使用vue-router切換頁(yè)面時(shí),獲取上一頁(yè)url以及當(dāng)前頁(yè)面url的方法
- vue 路由頁(yè)面之間實(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)頁(yè)面切換滑動(dòng)效果
相關(guān)文章
對(duì)Vue.js之事件的綁定(v-on: 或者 @ )詳解
今天小編就為大家分享一篇對(duì)Vue.js之事件的綁定(v-on: 或者 @ )詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2018-09-09使用webpack-obfuscator進(jìn)行代碼混淆及報(bào)錯(cuò)解決過程
隨著前端應(yīng)用的復(fù)雜度增加,保護(hù)客戶端的JavaScript代碼變得更為重要,webpack-obfuscator插件通過對(duì)代碼進(jìn)行混淆,如變量重命名、字符串加密等,提高代碼的保密性,防止源碼被輕易查看或修改2024-10-10某些場(chǎng)景下建議vue query代替pinia原理解析
這篇文章主要為大家介紹了某些場(chǎng)景下建議vue-query代替pinia原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02非Vuex實(shí)現(xiàn)的登錄狀態(tài)判斷封裝實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于非Vuex實(shí)現(xiàn)的登錄狀態(tài)判斷封裝的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-02-02Vue.js實(shí)戰(zhàn)之利用vue-router實(shí)現(xiàn)跳轉(zhuǎn)頁(yè)面
對(duì)于單頁(yè)應(yīng)用,官方提供了vue-router進(jìn)行路由跳轉(zhuǎn)的處理,這篇文章主要給大家介紹了Vue.js實(shí)戰(zhàn)之利用vue-router實(shí)現(xiàn)跳轉(zhuǎn)頁(yè)面的相關(guān)資料,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-04-04vue3+element?Plus實(shí)現(xiàn)表格前端分頁(yè)完整示例
這篇文章主要給大家介紹了關(guān)于vue3+element?Plus實(shí)現(xiàn)表格前端分頁(yè)的相關(guān)資料,雖然很多時(shí)候后端會(huì)把分頁(yè),搜索,排序都做好,但是有些返回?cái)?shù)據(jù)并不多的頁(yè)面,或者其他原因不能后端分頁(yè)的通常會(huì)前端處理,需要的朋友可以參考下2023-08-08Vue3響應(yīng)式方案及ref?reactive的區(qū)別詳解
眾所周知ref和reactive都是用來(lái)作響應(yīng)式數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于Vue3響應(yīng)式方案及ref?reactive區(qū)別的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-12-12vue3使用elementPlus進(jìn)行table合并處理的示例詳解
虛擬數(shù)據(jù)中公司下有多個(gè)客戶,公司一樣的客戶,公司列需要合并,客戶如果一樣也需要合并進(jìn)行展示,所以本文給大家介紹了vue3使用elementPlus進(jìn)行table合并處理的實(shí)例,文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02Vue3中Vite和Vue-cli的特點(diǎn)與區(qū)別詳解
vue-cli是Vue早期推出的一款腳手架,使用webpack創(chuàng)建Vue項(xiàng)目,可以選擇安裝需要的各種插件,比如Vuex、VueRouter,下面這篇文章主要給大家介紹了關(guān)于Vue3中Vite和Vue-cli的特點(diǎn)與區(qū)別的相關(guān)資料,需要的朋友可以參考下2022-12-12vue.js使用代理和使用Nginx來(lái)解決跨域的問題
下面小編就為大家分享一篇vue.js使用代理和使用Nginx來(lái)解決跨域的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2018-02-02