react 组件根据props改变来执行一些操作

背景介绍

在react的componentWillReceiveProps(nextProps)生命周期中,可以在子组件的render函数执行前获取新的props,从而更新子组件自己的state。
这样的好处是,可以将数据请求放在这里进行执行,需要传的参数则从componentWillReceiveProps(nextProps)中获取。而不必将所有的请求都放在父组件中。于是该请求只会在该组件渲染时才会发出,从而减轻请求负担。

编码实战

componentWillReceiveProps()

  componentWillReceiveProps(nextProps) {
    const { ouUuid  } = this.props; // 获取组织编码参数
    const { ouUuidNext  } = nextProps; // 获取下一次传入组织编码参数
    if (ouUuid !== ouUuidNext) {
      console.log(ouUuid, ouUuidNext)
    }
  }

一定要通过nextProps参数获取,如果通过this.props.XXX,这个还是获取的上一个props中的值

componentDidUpdate()

componentDidUpdate(prevProps, prevState, snapshot)

componentDidUpdate() 会在更新后会被立即调用。首次渲染不会执行此方法。

当组件更新后,可以在此处对 DOM 进行操作。如果你对更新前后的 props 进行了比较,也可以选择在此处进行网络请求。(例如,当 props 未发生变化时,则不会执行网络请求)。

componentDidUpdate(prevProps) {
  // 典型用法(不要忘记比较 props):
  if (this.props.userID !== prevProps.userID) {
    this.fetchData(this.props.userID);
  }
}

你也可以在 componentDidUpdate()直接调用 setState(),但请注意它必须被包裹在一个条件语句里,正如上述的例子那样进行处理,否则会导致死循环。它还会导致额外的重新渲染,虽然用户不可见,但会影响组件性能。不要将 props “镜像”给 state,请考虑直接使用 props。 欲了解更多有关内容,请参阅为什么 props 复制给 state 会产生 bug

如果组件实现了 getSnapshotBeforeUpdate() 生命周期(不常用),则它的返回值将作为 componentDidUpdate() 的第三个参数 “snapshot” 参数传递。否则此参数将为 undefined。

注意

如果 shouldComponentUpdate() 返回值为 false,则不会调用 componentDidUpdate()

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React 中,父组件的样式可以通过给父组件的 DOM 元素添加类名或样式属性来设置,而子组件的样式一般是通过在子组件中定义样式并使用 CSS Modules 或者 CSS-in-JS 的方式来实现。 父组件可以通过传递 props 给子组件来影响子组件的样式。比如可以定义一个 props,根据 props 的值来动态设置子组件的样式。子组件可以通过 props 接收父组件传递过来的样式,并应用到自己的 DOM 元素上。 举个例子,假设有一个父组件 Parent 和一个子组件 Child,代码如下: ```jsx // Parent.jsx import React from 'react'; import Child from './Child'; const Parent = () => { const style = { backgroundColor: 'red', color: 'white', padding: '10px', }; return ( <div className="parent" style={style}> <Child backgroundColor="blue" /> </div> ); }; export default Parent; // Child.jsx import React from 'react'; import styles from './Child.module.css'; const Child = ({ backgroundColor }) => { const style = { backgroundColor, color: 'white', padding: '10px', }; return <div className={styles.child} style={style}>Child Component</div>; }; export default Child; ``` 在上面的例子中,父组件 Parent 给自己的 DOM 元素添加了一个类名 parent,并设置了一些样式。同时,父组件也传递了一个 props backgroundColor 给子组件 Child。子组件通过 props 接收到 backgroundColor,将其应用到自己的 DOM 元素上,并定义了一个 CSS Modules 样式类 child。 需要注意的是,子组件的样式并不会影响父组件的样式,也就是说,子组件中定义的样式只会应用到子组件的 DOM 元素上,并不会影响到父组件的样式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值