溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

React的組件通訊是什么

發(fā)布時(shí)間:2021-11-09 18:48:45 來(lái)源:億速云 閱讀:185 作者:柒染 欄目:開(kāi)發(fā)技術(shù)

本篇文章為大家展示了React的組件通訊是什么,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

    組件通訊介紹

    內(nèi)容

    • 組件是獨(dú)立且封閉的單元,默認(rèn)情況下,只能使用組件自己的數(shù)據(jù)。

    • 在組件化過(guò)程中,我們將一個(gè)完整的功能拆分成多個(gè)組件,以更好的完成整個(gè)應(yīng)用的功能。

    • 而在這個(gè)過(guò)程中,多個(gè)組件之間不可避免的要共享某些數(shù)據(jù)

    • 為了實(shí)現(xiàn)這些功能,就需要打破組件的獨(dú)立封閉性,讓其與外界溝通。這個(gè)過(guò)程就是組件通訊。

    三種方式

    • 父子組件之間

    • 兄弟組件之間

    • 跨組件層級(jí)

    小結(jié)

    組件中的狀態(tài)是私有的,也就是說(shuō),組件的狀態(tài)只能在組件內(nèi)部使用,無(wú)法直接在組件外使用

    組件通訊-父?jìng)髯?/h3>

    內(nèi)容:

    • 父組件提供要傳遞的state數(shù)據(jù)

    • 給子組件標(biāo)簽添加屬性,值為 state 中的數(shù)據(jù)

    • 子組件中通過(guò) props 接收父組件中傳遞的數(shù)據(jù)

    核心代碼

    父組件提供數(shù)據(jù)并且傳遞給子組件

    class Parent extends React.Component {
        state = { lastName: '王' }
        render() {
            return (
                <div>
                    傳遞數(shù)據(jù)給子組件:<Child name={this.state.lastName} />
                </div>
            )
        }
    }

    子組件接收數(shù)據(jù)

    function Child(props) {
    	return <div>子組件接收到數(shù)據(jù):{props.name}</div>
    }

    組件通訊-子傳父

    思路

    利用回調(diào)函數(shù),父組件提供回調(diào),子組件調(diào)用,將要傳遞的數(shù)據(jù)作為回調(diào)函數(shù)的參數(shù)。

    步驟

    1.父組件

    1.定義一個(gè)回調(diào)函數(shù)f(將會(huì)用于接收數(shù)據(jù))

    2.將該函數(shù)f作為屬性的值,傳遞給子組件

    2.子組件

    1.通過(guò) props 獲取f

    2.調(diào)用f,并傳入將子組件的數(shù)據(jù)

    核心代碼

    父組件提供函數(shù)并且傳遞給子組件

    class Parent extends React.Component {
        state: {
          num: 100
        }
        f = (num) => {
            console.log('接收到子組件數(shù)據(jù)', num)
        }
        render() {
            return (
                <div>
                	子組件:<Child f={this.f} />
                </div>
            )
        }
    }

    子組件接收函數(shù)并且調(diào)用

    class Child extends React.Component {
        handleClick = () => {
          // 調(diào)用父組件傳入的props,并傳入?yún)?shù)
        	this.props.f(100)
        }
        return (
        	<button onClick={this.handleClick}>點(diǎn)我,給父組件傳遞數(shù)據(jù)</button>
        )
    }

    小結(jié)

    子傳父:在子組件中調(diào)用從父組件中定義的方法,并根據(jù)需要傳入?yún)?shù)

    組件通訊-兄弟組件

    在React中沒(méi)有確定的兄弟組件,就沒(méi)有這個(gè)說(shuō)法哈,有的只有狀態(tài)提升.

    思路

    • 將共享狀態(tài)提升到最近的公共父組件中,由公共父組件管理這個(gè)狀態(tài)

    • 思想:狀態(tài)提升

    • 公共父組件職責(zé):

      • 提供共享狀態(tài)

      • 提供操作共享狀態(tài)的方法

    • 要通訊的子組件只需通過(guò) props 接收狀態(tài)或操作狀態(tài)的方法

    React的組件通訊是什么

    核心代碼

    parent.js

    import React, { Component } from 'react'
    import ReactDOM from 'react-dom'
    import Jack from './Jack'
    import Rose from './Rose'
    class App extends Component {
      // 1. 狀態(tài)提升到父組件
      state = {
        msg: '',
      }
      render() {
        return (
          <div>
            <h2>我是App組件</h2>
            <Jack say={this.changeMsg}></Jack>
            {/* 2. 把狀態(tài)給子組件顯示 */}
            <Rose msg={this.state.msg}></Rose>
          </div>
        )
      }
      changeMsg = (msg) => {
        this.setState({
          msg,
        })
      }
    }
    // 渲染組件
    ReactDOM.render(<App />, document.getElementById('root'))

    Son1.js

    import React, { Component } from 'react'
    export default class Jack extends Component {
      render() {
        return (
          <div>
            <h4>我是Jack組件</h4>
            <button onClick={this.say}>說(shuō)</button>
          </div>
        )
      }
      say = () => {
        this.props.say('you jump i look')
      }
    }

    Son2.js

    import React, { Component } from 'react'
    export default class Rose extends Component {
      render() {
        return (
          <div>
            <h4>我是Rose組件-{this.props.msg}</h4>
          </div>
        )
      }
    }

    組件通訊 -跨級(jí)組件通訊

    想在vue中使用跨級(jí)組件通訊,需要使用Context

    使用Context的步驟

    共三步:

    1.導(dǎo)入并調(diào)用createContext方法,從結(jié)果中解構(gòu)出 Provider, Consumer 組件

    import { createContext } from 'react'
    const { Provider, Consumer } = createContext()

    2.使用 Provider 組件包裹根組件,并通過(guò) value 屬性提供要共享的數(shù)據(jù)

    return (
      <Provider value={ 這里放要傳遞的數(shù)據(jù) }>
      	<根組件的內(nèi)容/>
      </Provider>
    )

    3.在任意后代組件中,使用第2步中導(dǎo)出的Consumer組件包裹整個(gè)組件

    return (
    	<Consumer>
      	{
          (data) => {
          	// 這里的形參data 就會(huì)自動(dòng)接收Provider中傳入的數(shù)據(jù)
            // console.log(data)
          	return <組件的內(nèi)容>
        	}
        }
      </Consumer>
    )

    落地代碼

    建立context.js文件

    import { createContext } from 'react'
    const { Provider, Consumer } = createContext()
    export { Consumer, Provider }

    改造根組件

    import { Provider } from './context'
    render () {
        return (
          <Provider value={{ num: this.state.num }}>
            <div>
              根組件, num: {this.state.num}
              <Parent />
              <Uncle />
            </div>
          </Provider>
        )
      }

    改造后代組件 Uncle.js

    import React from 'react'
    import { Consumer } from './context'
    export default class Uncle extends React.Component {
      render () {
        return (
          <Consumer>
            {(data) => {
              return <div>我是Uncle組件, {data.num}</div>
            }}
          </Consumer>
        )
      }
    }

    上述內(nèi)容就是React的組件通訊是什么,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

    向AI問(wèn)一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI