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 回到之前的页面。

相关推荐
星栈独行2 小时前
Makepad 应用如何读文件、调接口、保存数据
前端·程序人生·ui·rust·github
IT_陈寒2 小时前
Vite热更新失效?可能你在用Windows
前端·人工智能·后端
tedcloud1233 小时前
taste-skill部署教程:打造个性化AI推荐工作流
服务器·前端·人工智能·系统架构·edge
xinhuanjieyi3 小时前
html修复游戏种太阳错误
前端·游戏·html
林希_Rachel_傻希希4 小时前
学React治好了我的焦虑症,1小时速通React 前20分钟。
前端·javascript·面试
Cache技术分享4 小时前
435. Java 日期时间 API - Clock 灵活获取当前时间
前端·后端
独泪了无痕5 小时前
Vue3中防御XSS攻击的“特效药”-DOMPurify
前端·vue.js·安全
小小19925 小时前
idea 配置less转化为css
前端·css·less
hhb_6185 小时前
Less嵌套避坑:优先级冲突实战解析
前端·css·less