当前位置: 首页 > news >正文

组件重新装载时 useSWR 会发起请求

默认情况下,组件重新装载时 useSWR 会发起请求。这是 SWR "stale-while-revalidate" 设计哲学的一部分。

重新装载时的行为

function MyComponent() {const { data } = useSWR('/api/data', fetcher)// 组件卸载又重新挂载时:// 1. 立即显示缓存数据(如果存在)// 2. 在后台发起新请求验证数据是否更新// 3. 如果有更新,静默替换数据
}

重新装载的常见场景

场景1:路由导航

// 从 /page-a 导航到 /page-b,再返回 /page-a
// PageA 组件会卸载又重新挂载,触发重新验证
function PageA() {const { data } = useSWR('/api/page-a', fetcher) // 重新挂载时会请求return <div>Page A: {data}</div>
}

场景2:条件渲染

function ToggleComponent() {const [show, setShow] = useState(true)return (<div><button onClick={() => setShow(!show)}>Toggle</button>{show && <DataComponent />} // 切换时会卸载/重新挂载</div>)
}function DataComponent() {const { data } = useSWR('/api/data', fetcher) // 重新显示时会请求return <div>{data}</div>
}

场景3:键值变化导致的重新挂载

function UserProfile({ userId }) {// 当 userId 变化时,组件实际上会重新挂载const { data } = useSWR(`/api/user/${userId}`, fetcher)return <div>User: {data?.name}</div>
}

如何控制重新装载时的行为

1. 完全禁止重新验证

const { data } = useSWR('/api/data', fetcher, {revalidateOnMount: false // 重新挂载时不请求
})

2. 智能控制(推荐)

const { data } = useSWR('/api/data', fetcher, {revalidateIfStale: false // 有缓存就不重新验证,如果 key 发生变化或者存在定时刷新,useSWR 也会正常发起新的请求。
})

3. 使用不可变数据

import useSWRImmutable from 'swr/immutable'const { data } = useSWRImmutable('/api/data', fetcher) // 永远不会自动重新验证

4. 延长去重间隔

const { data } = useSWR('/api/data', fetcher, {dedupingInterval: 60000 // 60秒内避免重复请求
})

为什么这是默认行为?

useSWR 选择在重新装载时请求是因为:

  1. 数据新鲜度:确保用户看到最新数据
  2. 后台更新:用户体验无中断(先显示缓存,后台更新)
  3. 一致性:保持多设备间数据同步
  4. 错误恢复:自动重试失败的请求

实际应用建议

// 根据数据类型选择合适的策略
function SmartComponent() {// 实时数据:使用默认行为const { data: notifications } = useSWR('/api/notifications', fetcher)// 静态数据:禁止重新验证const { data: countries } = useSWR('/api/countries', fetcher, {revalidateIfStale: false})// 用户数据:中等刷新频率const { data: user } = useSWR('/api/user', fetcher, {dedupingInterval: 30000 // 30秒内不重复请求})return <div>{/* ... */}</div>
}

总结:组件重新装载时默认会请求,这是为了保持数据新鲜度。你可以通过配置来精确控制这个行为。

http://www.sczhlp.com/news/119336/

相关文章:

  • kettle插件-kettle数据清洗插件,轻松处理脏数据
  • 中二
  • 做一个英文网站在潮州哪里找做网站的
  • 学做网站要学什么星沙做网站
  • 建设公司需要网站吗wordpress 置顶特色
  • 如何在中国建设银行网站转账做知识产权相关的网站
  • 广东免费建站公司西丽网站建设设计
  • 怎样在手机做自己的网站6慕枫宁波网站建设
  • 手机网站锁定竖屏看代码wordpress aff
  • 做整站优化WordPress获取文章封页图
  • 开发设计公司网站微信营销推广
  • 物联网平台网站优化网站广告优化
  • 网站内存不足广州网站推广方案
  • 建立网站主页注意那些方面卖保温杯去什么网站做推广
  • 怎么在58建设企业的网站厦门建筑信息网
  • 设计好看的企业网站企业网站排名软件能优化
  • 电子商务网站的规划与建设论文企业门户是什么意思
  • web应用程详解part1
  • Seedream 4.0 简直绝了!
  • 财务管理NPV与IRR投资分析在IT行业案例
  • 网站建设进什么分录多用户商城源码开发
  • 广州做网站制作公司wordpress主题不分页
  • 个人网站 商业好的手机网站
  • 做it软件的网站快餐网站模板
  • 鸭梨网站建设wordpress 上帝模式
  • 无锡做公司网站哈尔滨快速制作网站
  • 我想自己建个网站买货 怎么做asp网站攻击
  • 优化sigmoid
  • mysql查询死锁,mysql查询死锁方法
  • 【IEEE出版、已连续5届稳定快速EI检索】第六届计算机工程与智能控制学术会议(ICCEIC 2025)