javascript

推荐列表 站点导航

当前位置:首页 > 脚本编程 > javascript >

react中的portal是做什么的

来源:网络整理  作者:  发布时间:2020-12-21 02:22
react中的portal可以将子组件渲染到非父组件的子树下,同时父组件仍能对子组件做出反应。使用方法如【ReactDOM.creat...

先获取页面中Dog窝和Cat窝

作用:

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组件

代码实现:

将子组件渲染到非父组件的子树下,同时父组件仍能对子组件做出反应,我们甚至不用做过多的dom处理。

本文环境:windows10、react16,本文适用于所有品牌的电脑。

react中的portal是做什么的

现在有两个组件,Dog和Cat,我们想让Dog的子组件Puppy放到Cat里,当欺负Puppy的时候,即使相隔千里Dog也能感受到。

举例:

react中的portal可以将子组件渲染到非父组件的子树下,同时父组件仍能对子组件做出反应。使用方法如【ReactDOM.createPortal(this.props.children, this.el);】。

const dogRoot = document.getElementById("dog-house"); const catRoot = document.getElementById("cat-house");

创建一个Puppy组件

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是做什么的的详细内容,更多请关注聚合云库其它相关文章!

(学习视频分享:react视频教程

相关热词:

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://www.juheyunku.com/jiaob/javascript/6445.shtml

最新文章
Javascript是什么? Javascript是什么?

时间:2021-01-04

Canvas入门实战之实现一个 Canvas入门实战之实现一个

时间:2021-01-04

11月份GitHub上最热门的Ja 11月份GitHub上最热门的Ja

时间:2021-01-04

一篇带给你JavaScript的Cla 一篇带给你JavaScript的Cla

时间:2021-01-04

详解js异步文件加载器 详解js异步文件加载器

时间:2021-01-04

深入理解JavaScript中的箭头 深入理解JavaScript中的箭头

时间:2021-01-04

复盘Node项目中遇到的13+常 复盘Node项目中遇到的13+常

时间:2021-01-04

连续3年稳居第一,全球 连续3年稳居第一,全球

时间:2021-01-04

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

react中的portal是做什么的

2020-12-21 编辑:

先获取页面中Dog窝和Cat窝

作用:

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组件

代码实现:

将子组件渲染到非父组件的子树下,同时父组件仍能对子组件做出反应,我们甚至不用做过多的dom处理。

本文环境:windows10、react16,本文适用于所有品牌的电脑。

react中的portal是做什么的

现在有两个组件,Dog和Cat,我们想让Dog的子组件Puppy放到Cat里,当欺负Puppy的时候,即使相隔千里Dog也能感受到。

举例:

react中的portal可以将子组件渲染到非父组件的子树下,同时父组件仍能对子组件做出反应。使用方法如【ReactDOM.createPortal(this.props.children, this.el);】。

const dogRoot = document.getElementById("dog-house"); const catRoot = document.getElementById("cat-house");

创建一个Puppy组件

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是做什么的的详细内容,更多请关注聚合云库其它相关文章!

(学习视频分享:react视频教程

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://www.juheyunku.com/jiaob/javascript/6445.shtml

相关文章

风云图片

推荐阅读

返回javascript频道首页