vue tabbar 如何利用嵌套路由 实现页面切换 以及记录高度 非history模式

13 篇文章 0 订阅

项目中有时用到多个页面 记录滚动高度  让用户有更好的体验

利用路由实现 嵌套路由 监听高度 

项目源码 

<template>
    <div id="tabs" class="tabs">
        <div>{{active}}</div>
        <keep-alive>
            <router-view ></router-view>
        </keep-alive>
        <van-tabbar v-model="active">
            <van-tabbar-item  to="/tabs/tabs_list"   icon="home-o" >
                列表
                <van-icon
                slot="icon"
                slot-scope="props"
                :name="props.active  ? store_pes : store"
                ></van-icon>
            </van-tabbar-item>
            <van-tabbar-item  to="/tabs/tabs_user"  icon="search">用户
                <van-icon
                        slot="icon"
                        slot-scope="props"
                        :name="props.active  ? my_pes : my"
                ></van-icon>
            </van-tabbar-item>
        </van-tabbar>

    </div>
</template>

关键代码 <keep-alive> <router-view ></router-view> </keep-alive> 利用抽象组件缓存当前数据

嵌套路由配置
{
    name: 'tabs',
    component: () => import('./views/test/tabs'),
    path: '/tabs/tabs_list',
    children: [
        {
            name: 'tabs_list',
            component: () => import('./views/test/tabs_list'),
            path: '',
        },
        {
            name: 'tabs_user',
            component: () => import('./views/test/tabs_user'),
            path: '/tabs/tabs_user',
        }
    ]
}  ,

路由文件中进行高度监听

main.js 中声明
Vue.prototype.$pageScroll = {};//上个页面的滚动值

//route.js 
//高度放入数据中
router.beforeEach((to, from, next)=>{

    const title = to.meta.title ;
    let formName = from.name;
    //记录高度的路由名称 页面需求量不高的 可以用一下方法  这里也可以放入数组 也可以在 页面中进行此操作
    if(formName=='tabs_list'){
        let  scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
        if(formName&&parseInt(scrollTop)>-1){
            console.log(scrollTop)
            router.app.$pageScroll[formName] = scrollTop;
        }
    }
    if(title){
        document.title = title;
    }
     if(to.name!='login'){
        if(state.state.token==''||state.state.token==undefined){
            next({path:'/login'});
        }
    }
    next();

});

//在scrollBehavior 行为函数中操作

const router =  new VueRouter({
    routes,
    scrollBehavior(to,form,savedPosition){
        //scrollBehavior方法接收to,form路由对象
        //第三个参数savedPosition当且仅当在浏览器前进后退按钮触发时才可用
        //该方法会返回滚动位置的对象信息,如果返回false,或者是一个空的对象,那么不会发生滚动
        //我们可以在该方法中设置返回值来指定页面的滚动位置,例如:
        //表示在用户切换路由时让是所有页面都返回到顶部位置
        //如果返回savedPosition,那么在点击后退按钮时就会表现的像原生浏览器一样,返回的页面会滚动过到之前按钮点击跳转的位置,大概写法如下:
        console.log(router.app.$pageScroll[to.name])
        if(savedPosition){
            console.log(savedPosition)
            return savedPosition
        }else{
            if(router.app.$pageScroll[to.name]>0){
                console.log('设定滚动高度')
                return {x:0,y:router.app.$pageScroll[to.name]}
            }
        }
        //如果想要模拟滚动到锚点的行为:
        if(to.hash){
            return {
                selector:to.hash
            }
        }
    }
})

自己研究的方法 大家有好方法可以互相交流  QQ邮箱:1012654345@qq.com

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue Router 是 Vue.js 官方的由管理器。它和 Vue.js 的核心深度集成,可以常方便的实现页面应用程序的由功能。 Vue Router 提供了以下两种方式实现页面由跳转: 1. 声明式导航:通过 `<router-link>` 组件实现页面跳转,该组件会被渲染成一个 `<a>` 标签,点击该标签后会触发由跳转。 2. 编程式导航:通过 `$router` 对象提供的方法实现页面跳转,例如 `$router.push()`、`$router.replace()`、`$router.go()` 等方法。 下面我们来看一个简单的示例,在 Vue Router 中如何实现页面由跳转: ```html <!-- 在模板中使用 router-link 组件 --> <router-link to="/home">Home</router-link> <!-- 在组件中使用 $router 对象实现编程式导航 --> <button @click="$router.push('/about')">About</button> ``` 在上面的示例中,我们分别演示了如何使用 `<router-link>` 组件和 `$router` 对象实现页面由跳转,其中 `to` 属性表示跳转的目标由地址。 此外,Vue Router 还支持嵌套的功能,可以通过嵌套由的方式实现页面嵌套展示。下面我们来看一个嵌套由的示例: ```javascript const router = new VueRouter({ routes: [ { path: '/home', component: Home, children: [ { path: 'news', component: News }, { path: 'videos', component: Videos } ] } ] }) ``` 在上面的示例中,我们定义了一个名为 `Home` 的由组件,并在该组件中嵌套了两个子由 `News` 和 `Videos`,这样就可以实现在 `Home` 组件中展示新闻和视频内容的功能。在实际开发中,我们可以根据实际需求来定义不同的由组件和子由,实现灵活的页面嵌套效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值