react中的portal是做什么的
程序员文章站
2022-03-08 19:17:21
...
react中的portal可以将子组件渲染到非父组件的子树下,同时父组件仍能对子组件做出反应;使用方法如【ReactDOM.createPortal(this.props.children, this.el);】。
本文环境:windows10、react16,本文适用于所有品牌的电脑。
作用:
将子组件渲染到非父组件的子树下,同时父组件仍能对子组件做出反应,我们甚至不用做过多的dom处理。
(学习视频分享:react视频教程)
举例:
现在有两个组件,Dog和Cat,我们想让Dog的子组件Puppy放到Cat里,当欺负Puppy的时候,即使相隔千里Dog也能感受到。
代码实现:
先获取页面中Dog窝和Cat窝
const dogRoot = document.getElementById("dog-house"); const catRoot = document.getElementById("cat-house");
创建一个Puppy组件
class Puppy extends React.Component { constructor(props) { super(props); // 创建一个容器标签 this.el = document.createElement("div"); } componentDidMount() { // 把容器标签挂到 catRoot DOM下 catRoot.append(this.el); } componentWillUnmount() { catRoot.removeChild(this.el); } render() { // 利用portal把Puppy的内容放到容器里 return ReactDOM.createPortal(this.props.children, this.el); } }
创建Dog组件
class Dog extends React.Component { constructor(props) { super(props); this.state = { bark: 0 }; this.handleClick = this.handleClick.bind(this); } handleClick() { // 点击的时候 bark + 1 this.setState((state) => ({ bark: state.bark + 1, })); } render() { // 看上去Puppy组件是在Dog挂在Dog组件里,但其实它被挂载在其它地方 return ( <div onClick={this.handleClick}> <p>The number of times a big dog barks: {this.state.bark}</p> <h3>Dog: </h3> <p>I can't see my children, but I can feel them</p> <Puppy> <Bully target={'Puppy'}/> </Puppy> <Bully target={'Dog'}/> </div> ); } } ReactDOM.render(<Dog />, dogRoot);
再创建一个代替欺负Puppy的按钮组件
function Bully(props) { return ( <> <button>Bully the {props.target}</button> </> ); }
相关推荐:js教程
以上就是react中的portal是做什么的的详细内容,更多请关注其它相关文章!
上一篇: jquery符号===和==区别是什么
推荐阅读
-
是电商品牌策划难做 还是你在策划的过程中迈错了步伐
-
从建站开始做SEO,云指建站简直是建站中的SEO神器
-
诸子百家中的“杂家”是做什么的?“杂家”的中心思想及代表人物一览
-
“诸弟之乱”中耶律阿保机是怎么成功化解 耶律阿保机是怎么做的
-
python中的django是做什么的
-
先秦诸子百家中的“小说家”是干什么的?真的是写小说的吗?
-
丁肇中:做实验,第一你不能讨论的是要多少钱
-
砒霜在古代到底是用来干什么的 为什么药铺中随便就能买到呢
-
postman做接口测试,body穿json格式的参数,json中的参数值是list类型,且列表项是图片时如何传参
-
是电商品牌策划难做 还是你在策划的过程中迈错了步伐