新版本react的context使用

Context 经过组件树提供了一个传递数据的方法,从而避免了在每个层级手动的传递 props 属性。html

在一个典型的 React 应用中,数据是经过 props 属性由上向下(由父及子)的进行传递的,但这对于某些类型的属性而言是极其繁琐的(例如:地区偏好,UI主题),这是应用程序中许多组件都所须要的。 Context 提供了一种在组件之间共享此类值的方式,而没必要经过组件树的每一个层级显式地传递 props 。react

参考文档: https://react.docschina.org/d...ide

connect.jsthis

import React from 'react'
const ctx = React.createContext()
export const { Provider, Consumer } = ctx
export const withComponent = Component => props => <Consumer>{ propsObj => <Component { ...props } propsObj={propsObj}></Component> }</Consumer>
export default ctx

index.js
在最外层组件引入 Provider(*注意Provider的value名字不能改变)code

import React, { Component } from 'react
import { Provider } from './connect.js
import Carder from './carder.js'
export default class Index extends Component {
    state = {
        testObj: {
            test: false,
            reverse: () => this.setState({...this.state.test.obj, test: !this.state.test})
        }
            
            
    }
    render() {
        return (
            <Provider value={this.state.testObj}>
                <Carder>
            </Provider>
        )
    }
}

carder.jshtm

import React, { Component } from 'react
import { withComponent } from './connect.js
class Carder extends Component {
    state = {
        test: false
    }
    render() {
        return (
            <div>
                <p>test的值为:{this.props.testObj.test}</p>
                <button onClick={this.props.testObj.reverse}>点击</button>
            </div>
        )
    }
}
export default withComponent(Carder )
相关文章
相关标签/搜索