Vue頁面堆棧管理器詳情
A vue page stack manager Vue
頁面堆棧管理器 vue-page-stack
示例展示了一般的前進、后退(有activited)和replace的場景,同時還展示了同一個路由可以存在多層的效果(輸入必要信息)
目前版本還沒有經過整體業(yè)務的測試,歡迎有同樣需求的進行試用
1、需求分析
由于重度使用了Vue全家桶在web App
、公眾號和原生Hybrid
開發(fā),所以很自然的會遇到頁面跳轉與回退這方面的問題。
場景舉例:
- 列表頁進入詳情頁,然后回退
- 某操作頁A需要在下一頁面B選擇,選擇后需要退回到A頁面(A頁面還要知道選擇了什么)
- 在任意頁面進入到登錄頁面,登錄或者注冊成功后返回到原頁面,并且要保證繼續(xù)回退是不會到登陸頁面的
- 支持瀏覽器的
back
和forward
(微信或者小程序很有用) - 在進入、退出或者某些特殊頁面的時候添加一些動畫,比如模仿
ios
的默認動畫(進入是頁面從右向左平移,退出是頁面從左向右平移)
2、嘗試過的方法
嘗試了以下方法,但是都沒有達到我的預期
2.1 keep-alive
一般是使用兩個router-view
通過route
信息和keep-alive
控制頁面是否緩存,這樣存在兩個問題:
keep-alive
對相同的頁面只會存儲一次,不會有兩個版本的相同頁面- 兩個
router-view
之間沒有辦法使用transition
等動畫
2.2 CSS配合嵌套route
曾經在查看cube-ui
的例子的時候,發(fā)現(xiàn)他們的例子好像解決了頁面緩存的問題,我借鑒(copy
)了他們的處理方式,升級了一下,使用CSS
和嵌套route
的方式實現(xiàn)了基本的需求。
但是也有缺點:
- 我必須嚴格按照頁面的層級來寫我的
route
- 很多頁面在多個地方需要用到,我必須都得把路由配上(例如商品詳情頁面,會在很多個地方有入口)
3、功能說明
- 在vue-router上擴展,原有導航邏輯不需改變
push
或者forward
的時候重新渲染頁面,Stack
中會添加新渲染的頁面- back或者go(負數(shù))的時候不會重新渲染,從Stack中讀取先前的頁面,會保留好先前的內容狀態(tài),例如表單內容,滾動條滑動的位置等
back
或者go(負數(shù))的時候會把不用的頁面從Stack中移除replace
會更新Stack
中頁面信息- 回退到之前頁面的時候有
activited
鉤子函數(shù)觸發(fā) - 支持瀏覽器的后退,前進事件
- 支持響應路由參數(shù)的變化,例如從
/user/foo
導航到/user/bar
,組件實例會被復用 - 可以在前進和后退的時候添加不同的動畫,也可以在特殊頁面添加特殊的動畫
4、安裝和用法
安裝:
npm install vue-page-stack # OR yarn add vue-page-stack
使用:
import Vue from 'vue' import VuePageStack from 'vue-page-stack'; // vue-router是必須的 Vue.use(VuePageStack, { router }); // App.vue <template> <div id="app"> <vue-page-stack> <router-view ></router-view> </vue-page-stack> </div> </template> <script> export default { name: 'App', data() { return { }; }, components: {}, created() {}, methods: {} }; </script>
5、API
5.1 注冊
注冊的時候可以指定VuePageStack
的名字和keyName
,一般不需要
Vue.use(VuePageStack, { router, name: 'VuePageStack', keyName: 'stack-key' });
5.2 前進和后退
想在前進、后退或者特殊路由添加一些動畫,可以在router-view
的頁面通過watch $route
,通過stack-key-dir
(自定義keyName
這里也隨之變化)參數(shù)判斷此時的方向,可以參考實例
6、相關說明
6.1 keyName
為什么會給路由添加keyName
這個參數(shù),是為了支持瀏覽器的后退,前進事件,這個特點在微信公眾號和小程序很重要
6.2 原理
獲取當前頁面Stack
部分參考了keep-alive
的部分
這個插件存在我心中很久了,斷斷續(xù)續(xù)做了好久,終于被我搞定了,真的非常開心。
目前版本還沒有經過整體業(yè)務的測試,歡迎有同樣需求的進行試用,有任何的意見或者建議,歡迎在 Github
提issue
和PR,感謝你的支持和貢獻。
這個插件同時借鑒了vue-navigation和vue-nav,很感謝他們給的靈感。
到此這篇關于Vue頁面堆棧管理器詳情的文章就介紹到這了,更多相關Vue頁面堆棧管理器內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
使用Vue-Router 2實現(xiàn)路由功能實例詳解
vue-router 2只適用于Vue2.x版本,下面我們是基于vue2.0講的如何使用vue-router 2實現(xiàn)路由功能,需要的朋友可以參考下2017-11-11vue/Element?UI實現(xiàn)Element?UI?el-dialog自由拖動功能實現(xiàn)
最近工作上需要在el-dialog基礎上進行些功能的改動,下面這篇文章主要給大家介紹了關于vue/Element?UI實現(xiàn)Element?UI?el-dialog自由拖動功能實現(xiàn)的相關資料,需要的朋友可以參考下2023-06-06vue實現(xiàn)父子組件之間的通信以及兄弟組件的通信功能示例
這篇文章主要介紹了vue實現(xiàn)父子組件之間的通信以及兄弟組件的通信功能,結合實例形式分析了vue.js組件間通信相關操作技巧,需要的朋友可以參考下2019-01-01