首页 > 解决方案 > react-portal onOpen 未触发

问题描述

react-portal由于最近升级React到 16.8.6 ,一直在尝试从 v2 迁移到 v4。

卡在 Portal 上,即使isOpen=true. 发现onOpen没有开火。关于如何更改代码的任何建议?

import * as React from 'react';
import { Portal } from 'react-portal';

import 'dialog-polyfill/dialog-polyfill.css';
import 'dialog-polyfill/dialog-polyfill.js';

import { Dialog, DialogTitle, DialogContent, DialogActions, Button } from 'react-mdl';

class Confirm extends React.Component {
  onOpen() {
    if (!this.dialog.showModal) {
      dialogPolyfill.registerDialog(this.dialog);
    }

    this.dialog.showModal();
  }

  closeDialog() {
    this.dialog.close();
    this.portal.closePortal();
  }

  render() {
    const props = this.props;

    return (
      <Portal ref={c => this.portal = c} onOpen={this.onOpen.bind(this)} isOpen={Boolean(props.callback)} {...props}>
        <dialog ref={c => this.dialog = c} className="mdl-dialog" style={props.style}>
          <DialogTitle>{props.title}</DialogTitle>
          <DialogContent>
            {props.message}
          </DialogContent>
          <DialogActions>
            <Button type='button' onClick={() => {this.closeDialog(); props.confirm();}}>Confirm</Button>
            <Button type='button' onClick={() => {this.closeDialog(); props.dismissConfirmation();}}>Cancel</Button>
          </DialogActions>
        </dialog>
      </Portal>
    );
  }
}

export default Confirm;

预期结果:弹出一个确认对话框。

在浏览器中,已经可以通过修改 css 看到对话框存在。

标签: react-portal

解决方案


最终意识到这是由于 openByClickOn 不再受支持。如中所述:

React-Portal v4 不支持 openByClickOn


推荐阅读