react 离开当前页面自定义拦截

        import { Prompt } from 'react-router'
        import { Modal} from 'antd';
         useEffect(() => {
           localStorage.setItem('isPrompt', true);// 离开
         }, []);

        <Prompt
          message={(location) => {
            if (localStorage.getItem('isPrompt')=='false') {
              return true;
            } else {
              Modal.confirm({
                title: '确认离开吗?',
                content: '需要关闭',
                okText: '关闭',
                cancelText: '取消',
                onOk() {
                    //操作等等
                  localStorage.setItem('isPrompt', false);
                  props.history.push({
                    pathname: `..${location.pathname}`,
                  })
                },
                onCancel() {
                  console.log('Cancel');
                },
              });
              return false;
            } }
          }
        />

 react 离开当前页面拦截自定义。

用localStorage来存储主要是因为使用useState()有奇怪的bug,点击 确认 后使用hook更新 isPrompt 的值似乎不能立即变值,导致会弹出两次Modal,不知道啥原因。。。想念angular了。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值