pc后台自适应移动手机转到h5(正则表达式,检查当前访问设备是不是移动端。)

const isMobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(

window.navigator.userAgent,

);

  1. 结尾的 i → 表示 忽略大小写
window.navigator.userAgent userAgent 是浏览器提供的字符串 里面包含 "这是什么设备/系统/浏览器" 浏览器的用户代理信息
  1. .test(userAgent) test 会判断:userAgent 字符串中是否包含正则里的关键字

在浏览器中,window.navigator 是一个内置对象,它包含:

  • 浏览器名称

  • 浏览器版本

  • 系统信息(iOS、Android、Windows...)

  • 是否是移动端

  • 是否支持某些功能(如定位、震动、剪贴板权限等)

可以理解成:

你想知道浏览器是谁,它都能告诉你。

(1)routes/basic.ts --- 在系统首页 Dashboard 路由做移动端跳转

✔ 你在 SYSTEM_ROUTE 里这样写:

项目访问 /dashboard

→ 如果是 移动端 :自动 redirect 重定向 到 /List(你的 H5 列表页)

→ 如果是 PC 端 :正常进入 /dashboard/statisticalAnalysis

复制代码
const isMobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(
  window.navigator.userAgent,
);
const dashboard = isMobile ? '/List' : '/dashboard/statisticalAnalysis';

export const SYSTEM_ROUTE: AppRouteRecordRaw = {
  path: '/dashboard',
  name: 'Dashboard',
  component: LAYOUT,
  redirect: dashboard,
  meta: {
    orderNo: 10,
    icon: 'ion:grid-outline',
    title: t('首页'),
  },
};

2routes/basic.ts --- 登录页动态选择 H5 或 PC 登录组件

复制代码
const isMobile = ...;

const loginComponent = isMobile
  ? () => import('/@/views/sys/login/H5Login.vue')
  : () => import('/@/views/sys/login/Login.vue');

export const LoginRoute = {
  path: '/login',
  name: 'Login',
  component: loginComponent,
  meta: {
    title: t('登录页'),
  },
};
  • 手机端 → 使用 H5 登录页:H5Login.vue

  • PC 端 → 使用 PC 登录页:Login.vue

3permissionGuard.ts --- 在路由守卫 beforeEach 中直接放行移动端

  • 只要是移动端

    不拦截,不校验 token,不重定向,直接放行所有路由

  • 这是你为了 H5 页面能自己控制跳转而加的逻辑。

复制代码
  const isMobile = ...;

  router.beforeEach(async (to, from, next) => {
    // 如果是移动设备,直接放行
    if (isMobile) {
      next();
      return;
    }
    ...
  });

4)basicRoutes 注册了 H5 List 页面

  • /List 就是你写的 H5 列表页

  • 设为 ignoreAuth: true → 不需要 token 也可以访问

  • 因为移动端被你允许"router.beforeEach 直接放行",所以能自由进入

复制代码
  export const LoginListRoute = {
    path: '/List',
    name: 'List',
    component: () => import('/@/views/sys/loginList/loginList.vue'),
    meta: {
      title: t('履职列表'),
      ignoreAuth: true,
    },
  };

二、总结:全项目移动端跳转逻辑

文件 位置 你写的逻辑 作用
routes/basic.ts SYSTEM_ROUTE PC → dashboard,Mobile → /List 首页根据设备类型跳转
routes/basic.ts LoginRoute Mobile → H5Login.vue 登录页按端区分
routes/basic.ts LoginListRoute 注册 /List 路由 H5 列表页入口
permissionGuard.ts beforeEach isMobile 直接 next() 移动端不走权限验证
相关推荐
Lancker3 天前
定制侠 一个国产纯血鸿蒙APP的诞生过程
android·华为·智能手机·鸿蒙·国产操作系统·纯血鸿蒙·华为鸿蒙
新诺韦尔API3 天前
手机三要素验证接口详细技术对接指南
大数据·智能手机·api
铁蛋AI编程实战3 天前
Falcon-H1-Tiny 微型 LLM 部署指南:100M 参数也能做复杂推理,树莓派 / 手机都能跑
java·人工智能·python·智能手机
AirDroid_cn4 天前
双机党:一台小米一台华为,怎样相互远程控制?
智能手机
玉梅小洋5 天前
手机 App 云端存储云服务选型指南
人工智能·智能手机·手机·工具开发·手机app开发
玉梅小洋5 天前
手机 App 跨平台框架统一目录构建
智能手机·手机·app开发
东哥笔迹6 天前
高通骁龙Android手机平台EIS基础pipeline(二)
智能手机
jian110586 天前
Android studio 调试flutter 运行自己的苹果手机上
flutter·智能手机·android studio
小锋学长生活大爆炸6 天前
【工具】手机控制iPixel LED屏实现转向和刹车联动、语音控制显示内容
智能手机·工具·led·车机·智能·diy·ipixel
Boxsc_midnight7 天前
【openclaw+imessage】【免费无限流量】集成方案,支持iphone手机+macos
ios·智能手机·iphone