亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2017年05月25日 11:34:04   作者:大灰狼的小綿羊哥哥  
本篇文章主要介紹了vue實(shí)現(xiàn)app頁(yè)面切換效果實(shí)例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧

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í)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 對(duì)Vue.js之事件的綁定(v-on: 或者 @ )詳解

    對(duì)Vue.js之事件的綁定(v-on: 或者 @ )詳解

    今天小編就為大家分享一篇對(duì)Vue.js之事件的綁定(v-on: 或者 @ )詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2018-09-09
  • 使用webpack-obfuscator進(jìn)行代碼混淆及報(bào)錯(cuò)解決過程

    使用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原理解析

    這篇文章主要為大家介紹了某些場(chǎng)景下建議vue-query代替pinia原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • 非Vuex實(shí)現(xiàn)的登錄狀態(tài)判斷封裝實(shí)例代碼

    非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-02
  • Vue.js實(shí)戰(zhàn)之利用vue-router實(shí)現(xiàn)跳轉(zhuǎn)頁(yè)面

    Vue.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-04
  • vue3+element?Plus實(shí)現(xiàn)表格前端分頁(yè)完整示例

    vue3+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-08
  • Vue3響應(yīng)式方案及ref?reactive的區(qū)別詳解

    Vue3響應(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-12
  • vue3使用elementPlus進(jìn)行table合并處理的示例詳解

    vue3使用elementPlus進(jìn)行table合并處理的示例詳解

    虛擬數(shù)據(jù)中公司下有多個(gè)客戶,公司一樣的客戶,公司列需要合并,客戶如果一樣也需要合并進(jìn)行展示,所以本文給大家介紹了vue3使用elementPlus進(jìn)行table合并處理的實(shí)例,文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2024-02-02
  • Vue3中Vite和Vue-cli的特點(diǎn)與區(qū)別詳解

    Vue3中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-12
  • vue.js使用代理和使用Nginx來(lái)解決跨域的問題

    vue.js使用代理和使用Nginx來(lái)解決跨域的問題

    下面小編就為大家分享一篇vue.js使用代理和使用Nginx來(lái)解決跨域的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2018-02-02

最新評(píng)論