无法在没有错误的情况下从外部打开模态 MaterializeCSS

Can't externally open modal without error MaterializeCSS

我有一个在页面底部弹出的标准模式,我还有一个功能可以在整个页面中创建许多不同的组件,所有这些组件都有一个 'play' 按钮,单击时调用在 props 中传递的函数,该函数更改模式的打开 属性

供参考:

  return (
    <div>
        <Period openModal={this.openModal} />
      <Modal
        open={this.state.isOpen}
        options={{
          ...
        }}
        trigger={document.getElementsByClassName('modal-trigger')}
      >
        Song Descp and misc
      </Modal>

    </div>
  );

当按下按钮时,模式弹出,但很快我就得到这个错误:

TypeError: document.getElementById(...) is null
_handleTriggerClick
node_modules/materialize-css/dist/js/materialize.js:2990

  2987 | var $trigger = $(e.target).closest('.modal-trigger');
  2988 | if ($trigger.length) {
  2989 |   var modalId = M.getIdFromTrigger($trigger[0]);
> 2990 |   var modalInstance = document.getElementById(modalId).M_Modal;
       | ^  2991 |   if (modalInstance) {
  2992 |     modalInstance.open($trigger);
  2993 |   }

我推断是因为我没有打开模态的模态触发器。

经过深思熟虑,我转到了调用触发模式的方法的按钮,并删除了我添加到其中的“modal-trigger”class 名称,现在它可以正常工作了。我仍然不确定这是否是从外部触发模态的最佳方法。