为 React Bootstrap 显示的触发器模式

IT技术 reactjs react-bootstrap
2021-04-13 07:44:10

http://react-bootstrap.github.io/components.html#modals - 我正在寻找一种方法来找到“shown.bs.modal”而不是“show.bs.modal”的触发事件。

我没有看到有关某些引导程序模态事件的任何文档:http : //getbootstrap.com/javascript/#modals-events

var NewPerson = React.createClass({

  getInitialState: function(){
    return { showModal: false };
  },

  componentDidMount: function() {
    // removed irrelevant code
  },

  close: function(){
    this.setState({ showModal: false });
  },

  open: function(){
    this.setState({ showModal: true });
  },

  submit: function(e) {
    // removed irrelevant code
  },
  render: function() {
    var Button = ReactBootstrap.Button;
    var ButtonInput = ReactBootstrap.ButtonInput;
    var Modal = ReactBootstrap.Modal;

    return (
      <div>
        <Button
          className="pull-right bottom-20"
          bsStyle='success'
          bsSize='large'
          onClick={this.open}
        >
          Create New Person
        </Button>

        <Modal id="new-person-modal" show={this.state.showModal} onHide={this.close}>
          <Modal.Header closeButton>
            <Modal.Title>Create a New Person!</Modal.Title>
          </Modal.Header>
          <Modal.Body>
            <form id="new-person-form" onSubmit={this.submit} accept-charset="UTF-8" method="POST" novalidate="novalidate">
              <div className="row">
                <div className="form-group col-md-12">
                  <input type="text" className="form-control" id="author" name="author" ref="author" placeholder="Author (First + Last)" required />
                </div>
              </div>
              <ButtonInput
                type="submit"
                value="Submit"
                bsStyle="success"
                bsSize="large"
                onSubmit={this.submit}
                disabled={this.state.disabled} />
            </form>
          </Modal.Body>
        </Modal>
      </div>
    );
  }
});

React.render(<NewPerson url="/person" />, document.getElementById('person-new'));

我什至试图通过在旁边的 jQuery 中完成它来破解它,这也不起作用。

<script type="text/javascript">
$(document).ready(function() {
  $('#new-person-modal').on('shown.bs.modal', function (e) {
    console.log('modal displayed');
    // now can execute dynamic JS
  });
});
</script>

知道如何触发“显示”事件吗?我在 react-bootstrap 源中也找不到任何东西。

3个回答

有一种正确的方法可以做到这一点:使用 onEntered 事件。

<Modal
  onEntered  = { function(){ console.log( "Modal is Shown" ) }}
> 

当显示模态的过渡完成时调用此事件。

共有 6 个转换触发器:

<Modal
  onExit     = { function(){ console.log( "onExit    " ) }}
  onExiting  = { function(){ console.log( "onExiting " ) }}
  onExited   = { function(){ console.log( "onExited  " ) }}

  onEnter    = { function(){ console.log( "onEnter   " ) }}
  onEntering = { function(){ console.log( "onEntering" ) }}
  onEntered  = { function(){ console.log( "onEntered " ) }}
>

以下是他们所做的:

onEnter     = Callback fired before the Modal transitions in

onEntering  = Callback fired as the Modal begins to transition in    

onEntered   = Callback fired after the Modal finishes transitioning in


onExit      = Callback fired right before the Modal transitions out

onExiting   = Callback fired as the Modal begins to transition out

onExited    = Callback fired after the Modal finishes transitioning out

在撰写本文时,尚未记录此解决方案。我正在提交一个拉取请求,所以希望他们能尽快更新文档。

最简单的方法是创建一个非可视化组件,该组件将在渲染时调用传递的函数并在 Modal.Body 内的某处渲染此组件:

render: function() {
    //...
    <Modal.Body>
      //...
      <Notifier onShown={this.onModalShown} />
      //...
    </Modal.Body>
    //...
}

更新:这是 Notifier 组件的实现方式:

var Notifier = React.createClass({
    componentDidMount: function(){
        this.props.onShown();
    },
    render: function() {
        return null;
    }
});
优秀的!为了帮助可能拥有此功能的其他人,请确保将函数 onModalShown() 添加到 Modal。
2021-05-24 07:44:10
对不应该存在的问题的一个很好的解决方案
2021-06-07 07:44:10
你能再分解一下吗?我不确定我是否了解此通知程序将如何工作。此外,React/JSX 还很新
2021-06-18 07:44:10

我也有同样的问题,这就是我尝试过的......

Class Modal extends React.Component {

        showModal(){
        let obj = this.refs.modal;
        //write the required code here
      }
render() {
    return (
      <div>
        <div className="standard-content">
              <p><a className="btn" onClick={this.showModal}  data-toggle="modal" data-target="#exampleModal">Modal popup</a></p>
        </div>
        <div ref="modal" className="modal" id="exampleModal" role="dialog" >
            <div className="modal-dialog">
              <div className="modal-content">
                <div className="modal-header">      
                    <h4 className="modal-title">Header area</h4> 
              </div>
              <div className="modal-body">
                   body goes here..               
              </div>
              </div>
            </div>
          </div>
      </div>

    );
  }
}

由于我使用的是 ES6,所以我采用了课堂方法。我为模态内容创建了一个容器 div 并提供了一个 ref 属性以供参考。然后点击标签,我附加了一个处理程序,当模态出现时它会触发。在 this.refs 的帮助下,您可以访问模态。希望对你有帮助。