taro移动端项目配置路由拦截器

taro移动端项目配置路由拦截器

前言

个人开源的leno-admin后台管理项目,前端技术栈:reactHooksant-design;后端技术栈:koamysqlredis,整个项目包含web端electron客户端mob移动端template基础模板,能够满足你快速开发一整套后台管理项目;如果你觉得不错,就为作者点个✨star✨吧,你的支持就是对我最大的鼓励;

演示地址

文档地址

源码github地址

事因

最近在闲暇时间之余,便开始着手于开发我自己个人的开源项目leno-admin的移动端,包含移动端h5页面和微信小程序,也遇到了不少taro的坑,在路由拦截上无法直接套用web端的路由拦截,又因为需要兼容小程序端,索性便自己封装一个路由拦截器,下面便直接上代码!

封装RouterMonitor组件

我们在components中封装一个组件,接收唯一一个传值,就是url当前路径的传值,然后将该组件在入口文件app.tsx中引入,每一次页面的变化,都会触发App组件,从而达到触发我们自己封装的路由拦截器,然后就将拦截逻辑写在组件中即可;

tsx 复制代码
// components/RouterMonitor.tsx 
import Taro from "@tarojs/taro";

// url为app.tsx传入的当前页面的路径
const RouterMonitor = (props: { url: string }) => { 
  const token = Taro.getStorageSync("leno-admin-mob-token");
  const { url } = props;
  // pages是所有页面在的主文件夹下面,所有配置在app.config.ts中的路由路径都是pages开头,
  // 可根据自己项目进行修改;
  const handleUrl = url.split("pages")[1]?.split("?")[0];
  // router-path是上一层路由的页面
  let routerPath = Taro.getStorageSync("router-path");

  if (token) {
    // 有token去login
    if (handleUrl === "/login/index" || handleUrl === "/" || !handleUrl) {
      Taro.switchTab({
        url: routerPath as string,
      });
    } else {
      // 非登录页面才需要存储路由路径
      Taro.setStorage({
        key: "router-path",
        data: "/pages" + handleUrl,
      });
    }
  } else {
    if (handleUrl !== "/login/index" && handleUrl !== "/") {
      Taro.redirectTo({
        url: "/pages/login/index",
      });
    }
  }

  return <></>;
};

export default RouterMonitor;

app.tsx

tsx 复制代码
// app.tsx
import { FC, ReactNode } from "react";
import "taro-ui/dist/style/index.scss";
import "./app.scss";
import "~/assets/icons/iconfont.scss";
import RouterMonitor from "./components/RouterMonitor";
interface AppProps {
  children: ReactNode;
}

const App: FC<AppProps> = ({ children }) => {
  return (
    <div>
      // 调用时传入当前页面路由路径
      <RouterMonitor url={window.location.href} />
      {children}
    </div>
  );
};

export default App;
相关推荐
计算机学姐13 小时前
基于微信小程序的图书馆座位预约系统【uniapp+springboot+vue】
vue.js·spring boot·微信小程序·小程序·java-ee·uni-app·intellij-idea
Dragon Wu19 小时前
Taro v4.2.0 scss使用“@/xxx“的配置方法
前端·小程序·taro·scss
WKK_20 小时前
uniapp 微信小程序使用TextEncoder,arrayBufferToBase64
微信小程序·小程序·uni-app
舟遥遥娓飘飘21 小时前
面向零基础初学者,从环境搭建到发布上线,手把手教你开发第一个微信小程序(第3章-认识项目结构)
微信小程序·小程序·notepad++
求学中--1 天前
ArkUI电商首页完整实战
华为·typescript·harmonyos
优睿远行1 天前
微信小程序自定义组件开发实战:从封装到发布的全流程指南
微信小程序·小程序·notepad++
Greg_Zhong1 天前
微信小程序中使用云函数调用豆包免费模型,部署云函数设置(触发器)执行每日自动生成书籍的文章赏析,完整过程
微信小程序·ai工程师·小程序中豆包模型调用·云函数配置触发器生成每日文章·微信云函数
eric*16881 天前
微信小程序全局安全水印组件实践:支持动态更新、全局生效、自定义样式
微信小程序·小程序
杰建云1672 天前
微信小程序自制全流程实测与避坑指南
微信小程序·小程序
布局呆星2 天前
Spring Boot+MyBatis-Plus+Vue3前后端协作Note
spring boot·typescript·vue·mybatis