vue2实现 pc端 和手机端UI页面不一样的时候,根据屏幕分辨率,切换路由

同一个项目pc端和手机端页面不一样的时候,可以根据屏幕分辨率来切换路由

先看页面效果吧,后面有完整的代码~~~

pc端

 手机端

 

 在router.js路由配置页面:注意要加上   meta:{requiresDesktop:true}

import Vue from "vue";
import Router from "vue-router";
import login from "@/view/login.vue";


// 手机
import slogin from "../view/phone/slogin.vue";

Vue.use(Router);

 const router  =   new Router({
  routes: [
    //pc
    {
      path: "/login",
      name: "login",
      component: login,
      meta:{requiresDesktop:true}
    
    },
    //手机
    {
      path: "/slogin",
      name: "slogin",
      component: slogin,
      meta:{requiresMobile:true}
    },
    
  ]
});
export default router
router.beforeEach((to, from, next) => {
  const isMobile = window.innerWidth < 768 // 设置移动设备的屏幕分辨率阈值
  if (to.matched.some(record => record.meta.requiresMobile) && !isMobile) {
    next('/login') // 如果路由需要移动设备而当前是桌面设备,则跳转到桌面路由
  } else if (to.matched.some(record => record.meta.requiresDesktop) && isMobile) {
    next('/slogin') // 如果路由需要桌面设备而当前是移动设备,则跳转到移动路由
  } else {
    next() // 否则继续正常导航
  }
})

这样就可以实现啦

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值