Nice-modal-react的使用

创建modal

ts 复制代码
import { Modal } from 'antd';
import NiceModal, { useModal } from '@ebay/nice-modal-react';
import WarningSvg from '@/assets/warning.svg?react';

export const BrowserNotSatisfiedModal = NiceModal.create(() => {
  const modal = useModal();
  const modalProps: any = NiceModal.antdModal(modal);
  modalProps.open = modalProps.visible;
  delete modalProps.visible;

  const handleOK = () => {
    modal.hide();
  };

  return (
    <Modal
      {...modalProps}
      title={
        <div>
          <WarningSvg
            style={{
              fontSize: '22px',
              marginRight: '12px',
              verticalAlign: 'top',
            }}
          />
          提示
        </div>
      }
      centered
      onOk={handleOK}
      okText="确定"
      cancelText="取消"
    >
      <p style={{ margin: '20px 0 40px' }}>
        浏览器版本过低,可能存在部分内容不兼容,建议升级浏览器后使用
      </p>
    </Modal>
  );
});

使用弹框

ts 复制代码
NiceModal.show(AppealDialog, props);

注意:这里NiceModal返回的是一个Promise 可以这样使用

ts 复制代码
 NiceModal.show(ConsumerFormModal, {
    fields: (headerFields?.fields as unknown as ConsumerFormField[]) ?? [],
    editRecod: record,
    isEdit: true,
    })
    .then(()=>{})
    .catch(()=>{})
    .finally(() => {
    setIsEditConsumerTableFlag?.(false);
    });
相关推荐
我的写法有点潮1 天前
JS中对象是怎么运算的呢
前端·javascript·面试
悠哉摸鱼大王1 天前
NV12 转 RGB 完整指南
前端·javascript
一壶纱1 天前
UniApp + Pinia 数据持久化
前端·数据库·uni-app
双向331 天前
【RAG+LLM实战指南】如何用检索增强生成破解AI幻觉难题?
前端
海云前端11 天前
前端人必懂的浏览器指纹:不止是技术,更是求职加分项
前端
青莲8431 天前
Java内存模型(JMM)与JVM内存区域完整详解
android·前端·面试
parade岁月1 天前
把 Git 提交变成“可执行规范”:Commit 规范体系与 Husky/Commitlint/Commitizen/Lint-staged 全链路介绍
前端·代码规范
青莲8431 天前
Java内存回收机制(GC)完整详解
java·前端·面试
pas1361 天前
29-mini-vue element搭建更新
前端·javascript·vue.js