国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

react 組件傳值的三種方法

2024-05-06 16:51:43
字體:
來源:轉載
供稿:網友

整理 react 組件傳值 三種方式

父組件向子組件傳值(通過props傳值)

子組件:

  class Children extends Component{    constructor(props){      super(props);    }    render(){      return(        <div>這是:{this.props.name}</div> // 這是 父向子      )    }  }

父組件:

  class App extends React.Component{    render(){      return(        <div>          <Children name="父向子"/>        </div>      )    }  }

父組件向子組件傳值(回調函數)

子組件

  class Children extends Component{    constructor(props){      super(props);    }    handerClick(){      this.props.changeColor('skyblue') // 執行父組件的changeColor 并傳參 必須和父組件中的函數一模一樣    }    render(){      return(        <div>          <div>父組件的背景色{this.props.bgcolor}</div> // 子組件接收父組件傳過來的值 bgcolor          <button onClick={(e)=>{this.handerClick(e)}}>改變父組件背景</button> // 子組件執行函數        </div>      )    }  }

父組件

  class Father extends Component{    constructor(props){      super(props)      this.state = {        bgcolor:'pink'      }    }    bgChange(color){      this.setState({        bgcolor:color      })    }    render(props){      <div style={{background:this.state.bgcolor}}>              // 給子組件傳遞的值 color         <Children bgcolor={this.state.bgcolor} changeColor={(color)=>{this.bgChange(color)}} />                           // changeColor 子組件的參數=color 當做形參      </div>    }  }

兄弟組件傳值(子傳給父,父再傳給另一個子)

子組件1

  class Children1 extends Component{    constructor(props){      super(props);    }    handerClick(){      this.props.changeChild2Color('skyblue')       // 改變兄弟組件的顏色 把changeChild2Color的參數傳給父    }    render(){      return(        <div>          <div>children1</div>          <button onClick={(e)=>{this.handerClick(e)}}>改變children2背景</button>        </div>      )    }  }

子組件2

  class Children2 extends Component{    constructor(props){      super(props);    }    render(){      return(        <div style={{background:this.props.bgcolor}}>        // 從父元素獲取自己的背景色          <div>children2 背景色 {this.props.bgcolor}</div>          // children2 背景色 skyblue        </div>      )    }  }  

父組件

class Father extends Component{  constructor(props){    super(props)    this.state = {      child2bgcolor:'pink'    }  }  onchild2bgChange(color){    this.setState({      child2bgcolor:color    })  }  render(props){    <div>      <Children1 changeChild2Color={(color)=>{this.onchild2bgChange(color)}} />      <Children2 bgcolor={this.state.child2bgcolor} />    </div>  }}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 岫岩| 定远县| 武川县| 会昌县| 南安市| 博乐市| 黄骅市| 荣成市| 买车| 酉阳| 聂荣县| 南通市| 二连浩特市| 平山县| 长阳| 绥棱县| 和平区| 定日县| 沅江市| 吉林市| 竹北市| 宁海县| 崇仁县| 汝阳县| 石棉县| 黔南| 贵州省| 祥云县| 桃园县| 南宁市| 济阳县| 新泰市| 和田市| 肃南| 全州县| 绥宁县| 乌鲁木齐县| 濮阳县| 龙南县| 方城县| 方城县|