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

React 第三十九节 React Router 中的 unstable_usePrompt Hook的详细用法及案例

React Router 中的 unstable_usePrompt 是一个用于在用户尝试离开当前页面时触发确认提示的自定义钩子,常用于防止用户误操作导致数据丢失(例如未保存的表单)。

一、unstable_usePrompt用途

防止意外离开页面:当用户在当前页面有未保存的变更时,阻止直接离开。

自定义提示消息:允许开发者指定浏览器默认确认对话框中显示的消息。

二、unstable_usePrompt 基本使用

import { unstable_usePrompt } from "react-router-dom";function EditForm() {const [inputValue, setInputValue] = useState("");const [isDirty, setIsDirty] = useState(false);// 启用提示:当 isDirty 为 true 时触发提示unstable_usePrompt({when: isDirty,message: "您有未保存的更改,确定要离开吗?",});const handleInputChange = (e) => {setInputValue(e.target.value);setIsDirty(true); // 标记为有未保存的更改};const handleSubmit = () => {// 提交数据后重置状态setIsDirty(false);};return (<div><input type="text" value={inputValue} onChange={handleInputChange} /><button onClick={handleSubmit}>保存</button></div>);
}

三、unstable_usePrompt 参数说明

参数
whenBoolean类型 控制是否启用提示。当为 true 时,用户尝试离开页面会触发确认对话框。
messageString类型 用户离开时显示的提示消息(部分浏览器可能忽略自定义消息,使用默认文案)。

四、unstable_usePrompt注意事项

4.1、API 稳定性

unstable_usePrompt实验性 API,未来 React Router 版本可能重命名或移除。需关注官方更新。

4.2、浏览器兼容性

部分浏览器(如 Chrome)允许自定义提示消息,但某些场景(如页面关闭)可能强制使用默认文案。

移动端浏览器可能限制自定义提示行为。

4.3、条件管理

确保 when 参数在适当的时候设置为 false(如数据提交后),避免错误拦截用户导航。

4.4、路由上下文

组件必须位于 <BrowserRouter> 或路由上下文内部,否则钩子无法正常工作。

五、unstable_usePrompt完整案例

import { unstable_usePrompt, Link } from "react-router-dom";function EditPage() {const [name, setName] = useState("");const [isDirty, setIsDirty] = useState(false);unstable_usePrompt({when: isDirty,message: "确定要放弃未保存的更改吗?",});return (<div><h1>编辑用户信息</h1><inputtype="text"value={name}onChange={(e) => {setName(e.target.value);setIsDirty(true); // 输入后标记为未保存}}/><buttononClick={() => {// 模拟保存操作setIsDirty(false);}}>保存</button><Link to="/">返回首页</Link></div>);
}

六、unstable_usePrompt 替代方案

如果担心 API 不稳定,可用 useBeforeUnload 处理页面关闭事件(但无法拦截应用内路由跳转):

import { useBeforeUnload } from "react-router-dom";useBeforeUnload(() => {if (isDirty) {return "您有未保存的更改!";}
});

注意:unstable_usePrompt,可以有效提升涉及敏感操作页面的用户体验,但需权衡其潜在风险。

http://www.xdnf.cn/news/437077.html

相关文章:

  • React 第四十节 React Router 中 useBeforeUnload的使用详细解析及案例说明
  • Jsp技术入门指南【十四】实现基于MySQL+JDBC+JSP数据库验证的登录界面与登录跳转功能
  • LeRobot 框架的核心架构概念和组件(上)
  • 阿里端到端多模态语音对话开源模型论文速读:Qwen2.5-Omni
  • 机器学习 Day16 聚类算法 ,数据降维
  • SpringBoot整合MQTT实战:基于EMQX构建高可靠物联网通信,从零到一实现设备云端双向对话
  • ubuntu 22.04 wifi网卡配置地址上网
  • 关于深度学习的一些模型算法
  • AR禁毒:科技赋能,筑牢防毒新防线
  • 【MySQL】变更缓冲区:作用、主要配置以及如何查看
  • 前端服务器部署分类总结
  • 【工具类】ssh,remote-ssh插件和sftp插件
  • 【Oracle专栏】扩容导致数据文件 dbf 丢失,实操
  • LeetCode_sql刷题(3482.分析组织层级)
  • 鸿蒙OSUniApp制作一个小巧的图片浏览器#三方框架 #Uniapp
  • STM32 之网口资源
  • 大模型微调实战:基于GpuGeek平台的低成本高效训练方案
  • 光流 | Matlab工具中的光流算法
  • 团结引擎开源车模 Sample 发布:光照渲染优化 动态交互全面体验升级
  • MySQL八股(自用)
  • 学习threejs,使用Physijs物理引擎,通过控制重力,实现多米诺骨牌效果
  • Python+Selenium爬虫:豆瓣登录反反爬策略解析
  • Myshell与清华联合开源TTS模型OpenVoiceV2,多语言支持,风格控制进一步增强~
  • 深度学习入门:卷积神经网络
  • CSS常用选择器
  • Flink SQL 将kafka topic的数据写到另外一个topic里面
  • RPM 包制作备查 SRPM 包编译
  • 通过MCP让LLM调用系统接口
  • PDF Base64格式字符串转换为PDF文件临时文件
  • RabbitMQ 快速上手:安装配置与 HelloWorld 实践(一)