合肥网站seo技术,做淘宝网站如何提取中间的提成,做电影下载网站需要什么软件,桂林两江四湖夜游时间某些情况下#xff0c;我们希望渲染的内容独立于父组件#xff0c;甚至是独立于当前挂载到的DOM元素中#xff08;默认都是挂载到id为root的DOM元 素上的#xff09;。 Portal 提供了一种将子节点渲染到存在于父组件以外的 DOM 节点的优秀的方案#xff1a;
第一个参数我们希望渲染的内容独立于父组件甚至是独立于当前挂载到的DOM元素中默认都是挂载到id为root的DOM元 素上的。 Portal 提供了一种将子节点渲染到存在于父组件以外的 DOM 节点的优秀的方案
第一个参数child是任何可渲染的 React 子元素例如一个元素字符串或 fragment第二个参数container是一个 DOM 元素
通常来讲当你从组件的 render 方法返回一个元素时该元素将被挂载到 DOM 节点中离其最近的父节点然而有时候将子元素插入到 DOM 节点中的不同位置也是有好处的
Modal组件案例
比如说我们准备开发一个Modal组件它可以将它的子组件渲染到屏幕的中间位置 步骤一修改index.html添加新的节点 步骤二编写这个节点的样式 步骤三编写组件代码
import React, {PureComponent} from react;
import ReactDom from react-dom
class Modal extends PureComponent {render() {return ReactDom.createPortal(this.props.children,document.getElementById(modal))}
}
class Home extends PureComponent {render() {return (divh2Home/h2Modalh2Title/h2/Modal/div);}
}
class App extends PureComponent {render() {return (divHome //div);}
}
export default App;