use-leave-confirm
v1.2.5
Published
Monited Data has been changed, when router changing or closing browser tab, browser will provide confirm box
Downloads
10
Readme
use-leave-confirm
检测页面数据的变化,在跳转、前景/返回、刷新等操作进行拦截并显示确认框,等待用户反馈 支持vue3、react18+
使用
npm install use-leave-confirm
vue使用
// 第一步 先在main.ts的首行引入
import "use-leave-confirm/index.css";
import { install as leaveConfirmInstall, } from "use-leave-confirm";
// 配置use-leave-confirm, 一定要注意setup router 后
app.use(leaveConfirmInstall);
// 第二步 数据监控的页面
import { useLeaveConfirm } from "use-leave-confirm";
const { snapshot, } = useLeaveConfirm(store.data);
react使用
// 第一步 先在main.ts的首行引入
import "use-leave-confirm/index.css";
import { extendReactHistory, } from "use-leave-confirm";
extendReactHistory();
// 第二步 数据监控的页面
import { useLeaveConfirm } from "use-leave-confirm";
const navigate = useNavigate();
const { snapshot } = useLeaveConfirm(() => form.getFieldsValue(), {
navigate,
});
快照更新
const { snapshot, } = useLeaveConfirm(store);
// 5秒后快照更新,根据新的数据快照进行监控
setTimeout(() => {
snapshot();
}, 5000);
子组件中多次获取snapshot
// 空参即可获取到上一个snapshot
const { snapshot, } = useLeaveConfirm();
// ...
snapshot();
// ...
配置确认框的文本
import { useLeaveConfirm } from "use-leave-confirm";
const { snapshot, } = useLeaveConfirm(store.data, {
contentText: 'After leaving, the edited content will be cleared',
confirmText: 'Confirm',
cancelText: 'Cancel',
});
微前端处理
// vue基座项目 需要加入如下
import { install as leaveConfirmInstall, } from "use-leave-confirm";
// 配置use-leave-confirm, 一定要注意setup router 后
app.use(leaveConfirmInstall);
// react基座项目 需要加入如下
import { extendReactHistory, } from "use-leave-confirm";
extendReactHistory();