欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue router自動判斷左右翻頁轉場動畫效果

 更新時間:2017年10月10日 16:21:38   作者:前端阿小  
最近公司項目比較少終于有空來記錄一下自己對vue-router的一些小小的使用心得,本文給大家分享vue router自動判斷左右翻頁轉場動畫效果,感興趣的朋友一起看看吧

前段時間做了一個移動端spa項目,技術基于 :vue + vue-router + vuex + mint-ui

因為使用了vue-cli腳手架的webpack模版,所有頁面都以.vue為后綴的文件作為一個組件

最近公司項目比較少終于有空來記錄一下自己對vue-router的一些小小的使用心得,

  一般的移動端口單頁應用在跳轉頁面時候會有相應的轉場動畫,比如:

  1. 從當前一級頁面跳轉二級頁面需要展示的轉場動畫是一級頁面向屏幕左邊移動消失的同時,

   二級頁面從屏幕的右邊向左邊移動出現。(類似翻書翻到下一頁的效果)

  2. 從當前二級頁面跳回一級頁面需要展示的轉場動畫是二級頁面向屏幕右邊移動消失的同時,

   一級頁面從屏幕的左邊向右邊移動出現。類似(翻書翻回到上一頁的效果)

  但是出現了一個問題:如何判斷當前頁面和將要跳轉頁面之間的層級關系呢?

我的解決辦法是:創(chuàng)建頁面 (組件)時,在定義頁面的router里通過設置頁面的path(訪問路徑 )屬性來區(qū)分組件之間的層級關系。

比如一個一級頁面 (組件) ‘A' 的訪問路徑為 ‘/A' 。他的二級頁面 ‘B' 的訪問路徑為 ‘/A/B' .

  那么在跳轉頁面之前,只需要比較當前頁面和將要跳轉到的頁面的路徑深度就可以動態(tài)設置轉場動畫了。

比如 ‘/A/B'的深度 >  ‘/A' 的深度那么 從B頁面跳轉到A頁面就應該是 效果2:(翻書翻回到上一頁的效果).

一 。首先父頁面

home.vue:

<!-- keepAlList是用來動態(tài)判斷組件是否需要keep-alive,建議保存到vuex中作為全局變量,至于下方的css動畫,看官可以按照喜好自由修改-->
<transition :name="transNa">
 <keep-alive :include="keepAlList">
 <router-view class="child-view"></router-view>
 </keep-alive>
</transition>
<style scoped>
.child-view {
 position: absolute;
 width: 100%;
 height: 100%;
 transition: all .5s ease;
 -webkit-transition: all .5s ease;
 -moz-transition: all .5s ease;
}
.rightin-enter,
.leftin-leave-active {
 opacity: 0;
 transform: translate3d(50% 0, 0);
 -webkit-transform: translate3d(50%, 0, 0);
 -moz-transform: translate3d(50%, 0, 0);
}
.leftin-enter,
.rightin-leave-active {
 opacity: 0;
 transform: translate3d(-50% 0, 0);
 -webkit-transform: translate3d(-50%, 0, 0);
 -moz-transform: translate3d(-50%, 0, 0);
}
</style>

二 。其次附上我的main.js片段(用來在跳轉頁面之前動態(tài)設置轉場動畫)

  main.js:

//進入路由之前設置攔截器
let noLoginList = ["login", "register", "forget", "home", "classify", "goodsDetial"];
router.routeInfo.beforeEach((to, from, next) => {
 let user = sessionStorage.getItem('user');
 //如果要去登錄頁面
 if (noLoginList.indexOf(to.name) >= 0) {
  if (!user || user == '') {
   //未登錄的狀態(tài)通行
   next();
   return;
  } else {
   if (["login", "register", "forget"].indexOf(to.name) >= 0) {
    //已登錄的狀態(tài)去首頁
    next({
     name: 'home'
    });
    return;
   } else {
    //已登錄的狀態(tài)去首頁
    next();
    return;
   }
  }
 } else {
  //去登錄頁面以外的頁面(以下是本文關鍵代碼)
  if (user && user != '') {
   //判斷是否為需要緩存組件,如果是添加組件名到數組
   if (to.meta.keepAlive) {
    const toName = to.name;
    let keepLi = store.getters.getKeepAlList;
    keepLi.indexOf(toName) < 0 ? keepLi.push(toName) : '';
    store.commit('SET_KEEPALLIST', keepLi);
   }
   //根據路徑名深度設置轉場動畫類型
   store.commit('SET_TRANSNA', (to.path.split('/').length < from.path.split('/').length ? 'leftin' : 'rightin'));
   next();
  } else {
   let toWhere = router.nameList.indexOf(to.name) >= 0 ? to : {name: 'home'};
   next({
    name: 'login',
    params: {
     jumpTo: {
      name: toWhere.name,
      params: toWhere.params,
      query: toWhere.query,
     },
    }
   });
  }
 }
});

總結

以上所述是小編給大家介紹的vue router自動判斷左右翻頁轉場動畫效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • 如何利用vue實現css過渡和動畫

    如何利用vue實現css過渡和動畫

    過渡Vue在插入、更新或者移除 DOM 時,提供多種不同方式的應用過渡效果這篇文章主要給大家介紹了關于如何利用vue實現css過渡和動畫的相關資料,需要的朋友可以參考下
    2021-11-11
  • 教你如何開發(fā)Vite3插件構建Electron開發(fā)環(huán)境

    教你如何開發(fā)Vite3插件構建Electron開發(fā)環(huán)境

    這篇文章主要介紹了如何開發(fā)Vite3插件構建Electron開發(fā)環(huán)境,文中給大家提到了如何讓 Vite 加載 Electron 的內置模塊和 Node.js 的內置模塊,需要的朋友可以參考下
    2022-11-11
  • vue組件間的參數傳遞實例詳解

    vue組件間的參數傳遞實例詳解

    這篇文章主要介紹了vue組件間的參數傳遞 ,需要的朋友可以參考下
    2019-04-04
  • Vue Router的手寫實現方法實現

    Vue Router的手寫實現方法實現

    這篇文章主要介紹了Vue Router的手寫實現方法實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • 深入理解Vue 的條件渲染和列表渲染

    深入理解Vue 的條件渲染和列表渲染

    本篇文章主要介紹了深入理解Vue 的條件渲染和列表渲染,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • vue在.js文件中引入store和router問題

    vue在.js文件中引入store和router問題

    這篇文章主要介紹了vue在.js文件中引入store和router問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 一篇帶你搞懂Vue中的自定義指令

    一篇帶你搞懂Vue中的自定義指令

    自定義指令,是Vue提供的一種擴展和定制的機制,使開發(fā)者能夠在組件中直接操作DOM、處理事件、添加樣式等,并提供了與第三方庫集成的方式,定義指令使得Vue在處理交互和DOM操作時更加靈活和強大,本文將帶大家搞懂Vue中的自定義指令,需要的朋友可以參考下
    2023-07-07
  • Vue中的計算屬性和axios基本使用回顧

    Vue中的計算屬性和axios基本使用回顧

    這篇文章主要介紹了Vue中的計算屬性和axios基本使用回顧,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue父子組件進行通信方式原來是這樣的

    vue父子組件進行通信方式原來是這樣的

    這篇文章主要為大家詳細介紹了vue父子組件進行通信方式,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • 在vue項目中引用Iview的方法

    在vue項目中引用Iview的方法

    iView 是一套基于 Vue.js 的開源 UI 組件庫,主要服務于 PC 界面的中后臺產品。這篇文章主要介紹了在vue項目中引用Iview的方法,需要的朋友可以參考下
    2018-09-09

最新評論