portal.php+作用,react中的portal是做什么的

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

b167681b485e40262e7d9d4abc667f3b.png

本文环境: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 (

The number of times a big dog barks: {this.state.bark}

Dog:

I can't see my children, but I can feel them

);

}

}

ReactDOM.render(, dogRoot);

再创建一个代替欺负Puppy的按钮组件function Bully(props) {

return (

<>

Bully the {props.target}

>

);

}

相关推荐:js教程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值