题外话(关于vue中与uniapp中使用vuex分模块调用的差异)
使用vuex分moduls模块之后,正常的在页面调用模块中的同步或异步方法,vue与uniapp的差异如下
vue:this.$store.commit('user/getLogin','')
uniapp:this.$store.commit('getLogin','') //哪怕是用mapAction也是一样不能有模块前缀,不然就找不到方法了
正题
uni-simple-router注意事项(这边默认考虑的是使用simple-router的跳转方法)
--跳转特点
-共性
1.每个tabbar页面打开呈现之后只会初始化一次,后续会一直保留该页面,跳转回tabbar页面也是一样,得用onShow()去刷新页面数据;
2.跳转到非tabbar页面,都会初始化页面,但是返回上一个页面,不会触发页面的初始化
3.通过simple-router方法传参,传递参数query要改写成params,接收时用this.$Route.query获取,注意,原生的onLoad(e){}获取参数的方法被破坏,最好不要使用
4.原生传参的话,一样可以使用this.$Route.query接收参数,h5端没问题,微信小程序端用原生接收参数的方法会出问题,综合而言,无论哪种传参,this.$Route.query接收参数即可
-h5端
1.任何页面的跳转包括tabbar页面的跳转也包括返回上一页的跳转,都会触发全局路由守卫的指令
-微信小程序端
1.首次打开小程序会触发一次路由守卫,不管是什么情况都这样
2.跳转到非tabbar页面,会触发路由守卫,返回上一个页面则不会触发
3.tabbar页面的跳转只能在底部点击按钮跳转,并且不会触发路由守卫,使用simple-router的方法跳转到tabbar任意一个页面都会失败
4.如果想要使用方法跳转到tabbar中某一个页面,那么这个方法只能是uniapp原生的路由跳转方法,并且使用uniapp原生跳转方法会触发路由守卫