Taro-02-页面路由

React Router
复制代码
<Route
  path="/user"
  element={<User />}
/>

路由动态注册。


Taro

路由配置在 app.config.ts

复制代码
export default defineAppConfig({
  pages: [
    'pages/index/index',
    'pages/user/index'
  ]
})

页面必须提前声明。


页面目录
复制代码
src
 ├─ pages
 │   ├─ index
 │   │   ├─ index.tsx
 │   │   └─ index.config.ts
 │
 │   └─ user
 │       ├─ index.tsx
 │       └─ index.config.ts
  • app.config.tswindow:全局默认
  • 每个路由的配置文件:只作用于 当前路由,若某个属性与全局配置冲突会覆盖
1. 导航栏 / 窗口外观(CommonConfig,页面和全局都能用)
字段 说明
navigationBarTitleText 导航栏标题
navigationBarBackgroundColor 导航栏背景色
navigationBarTextStyle 标题颜色 black / white
navigationStyle defaultcustom(自定义导航栏)
backgroundColor 窗口背景色
backgroundTextStyle 下拉 loading 样式 dark / light
enablePullDownRefresh 是否开启下拉刷新
onReachBottomDistance 触底距离(px)
pageOrientation 屏幕方向 auto / portrait / landscape

2. 页面专属(PageConfig 独有)

字段 说明
disableScroll 禁止页面上下滚动(只能写在页面配置)
usingWindowScroll 是否用整页滚动(仅 H5)
enableShareAppMessage 开启分享给好友
enableShareTimeline 开启分享到朋友圈
enablePageMeta 是否使用 <page-meta> / <navigation-bar>
usingComponents 页面级自定义组件
renderer 渲染后端 webview / skyline
styleIsolation 样式隔离策略

页面跳转

React:

复制代码
navigate('/user')

Taro:

复制代码
import Taro from '@tarojs/taro';

Taro.navigateTo({
  url: '/pages/user/index'
});

返回:

复制代码
Taro.navigateBack();

路由传参

React:

复制代码
navigate('/user?id=1')

Taro:

复制代码
Taro.navigateTo({
  url: '/pages/user/index?id=1'
});

接收:

  1. 组件顶层
TypeScript 复制代码
// 必须在函数组件顶层调用,遵守 React Hooks 规则
// 页面第一次进入并渲染时就有值
// 适合:用 router.params 做首屏渲染(标题、默认值、条件展示等)

const router = useRouter();        // 首次 render 快照(静态)
const router = useRouter(true);    // 始终读 Current.router(动态)

console.log(router.params.id);
  1. 页面加载完成时(useLoad)------更常用于副作用
TypeScript 复制代码
useLoad((options) => {
  const id = options.id; // 和 router.params 一致
  // 在这里:请求接口、初始化状态、埋点等
});
  1. 页面再次显示时(useDidShow)

从别的页 navigateBack 回来,或同一页被复用且参数可能变了时,若只在首次 render 读一次可能不够,可在 useDidShow 里再读:

TypeScript 复制代码
useDidShow(() => {
  const { params } = Taro.getCurrentInstance().router!;
  // 或 useRouter(true) 开启动态更新(见下)
});

页面栈

压栈

复制代码
A
 ↓
B

页面栈:

复制代码
[A,B]

返回:

复制代码
Taro.navigateBack();

redirectTo

替换当前页面

复制代码
A
 ↓
B

变:

复制代码
[B]

switchTab

跳 TabBar

复制代码
Taro.switchTab({
  url:'/pages/home/index'
})

变:

复制代码
[home]

要点: switchTab 不会把 Tab 页「压栈」,而是切换 Tab + 清理非 Tab 页。栈里最多只会剩 TabBar 页面,只会出现 [Tab1,Tab2] 这种混合栈。


reLaunch

清空所有页面

复制代码
Taro.reLaunch({
  url:'/pages/login/index'
})

变:

复制代码
[login]

用于:

复制代码
登录成功
退出登录
切换租户

要点: reLaunch 是最彻底的重置,不管目标是 Tab 还是普通页,结果都是单页栈。之后不能用 navigateBack 回到之前的页面。

相关推荐
KaMeidebaby29 分钟前
卡梅德生物技术快报|蛋白 N 端测序在重组贻贝融合蛋白表征中的应用,解决原核表达序列偏移工艺难题
前端·人工智能·物联网·算法·百度
kyriewen2 小时前
我筛了 1400 个 Claude Code Skills,留下 5 个天天在用的
前端·ai编程·claude
JNX_SEMI2 小时前
AT2401C 2.4GHz 全集成射频前端单芯片技术解析
前端·单片机·嵌入式硬件·物联网·硬件工程
anOnion2 小时前
Agentic 前端开发之 实时显示 AI Agent 终端输出
前端·javascript·人工智能
随风一样自由2 小时前
【前端领域】2026最新前端领域全梳理(框架/工具/AI/跨端/底层标准/就业趋势)
前端·人工智能·前端框架
这是个栗子2 小时前
【前端性能优化】优化数据加载:用 Promise.all 从串行到并行
前端·javascript·性能优化·异步编程·前端优化·promise.all
fei_sun3 小时前
黑洞路由(Null Route/空接口路由)
服务器·前端·javascript
大爱一家盟3 小时前
告别卡点BGM同质化 2026原创卡点音乐素材下载网站 TOP5 推荐
大数据·前端·人工智能
彦为君3 小时前
算法思维与经典智力题
java·前端·redis·算法
aa小小4 小时前
localhost 访问异常排查笔记
前端