前端实用案例让前端飞Web前端之路

进击的 react Protals组件使用

2019-08-07  本文已影响1人  一只大橘

Portals是什么?用来干啥?。
翻译过来 就是“传送门”,是React 16版本中新加的组件功能。
使用场景:
当父组件有overflow,z-index样式的时候,但是你需要子组件在视觉上能够跳出容器,
也就是说能显示出来。比如对话框,提示框等。

下面这个例子可以直接在项目中使用

import React from 'react';
import ReactDOM from 'react-dom';
import PropTypes from 'prop-types';

function createPortal() {
  class Portal extends React.Component {
    constructor(props) {
      super(props);
      this.el = document.createElement('div');
      document.body.appendChild(this.el);
    }
    componentDidMount() {
      document.body.appendChild(this.el);
    }
    componentWillUnmount() {
      document.body.removeChild(this.el);
    }
    render() {
      return ReactDOM.createPortal(
        this.props.children,
        this.el,
      );
    }
  }
  Portal.propTypes = {
    children: PropTypes.any.isRequired,
  };
  return Portal;
}
export default createPortal();
上一篇下一篇

猜你喜欢

热点阅读