首頁 後端開發 php教程 React元件之間的通訊的實例

React元件之間的通訊的實例

Jun 28, 2017 pm 03:39 PM
react 實例 溝通

本篇文章主要介紹了React組件間通訊的實例程式碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟著小編過來看看吧

最近學習淺嘗則止的學習了一下react.js這個UI的框架,react這個庫給我的最大的感覺就是它能夠完全的接管UI層,在要改變視圖的東西的時候只需要改變其this.state中的狀態。只要操作資料層的東西視圖層就會發生變化,這一點我還是很喜歡的。可以擺脫對DOM的直接操作,畢竟直接來會比較複雜,本來應該是邏輯層js中混雜著各種css的字串,對於我來說有點不爽(JSX中也混雜著這標籤,但我覺的不應該把它看作標籤,看作語句會習慣一點)。

回到幾天的重點,講react元件之間的狀態傳遞。

上程式碼:

1.定義兩個子元件child-1與child-2


 //child-1 子组件-1为输入框
  class Input extends React.Component{
   constructor(...args){
   super(...args);
   }
   render(){
    return <input type="text"/>
   }
  }
  //child-2  子组-2为显示框
  class Show extends React.Component{
   constructor(...args){
    super(...args);
   }
   render(){
    return <p></p>
   }

  }
登入後複製


2.定義父元件Parent並且將兩個子元件插入到父元件中


class Parent extends React.Component{
   constructor(...args){
    super(...args);
   }
   render(){
    return(
     <p>
      <Input}/>
      <Show/>
     </p>
    );
   }
  }
登入後複製


現在的任務是在元件1總輸入一些文字,同時在元件2中同時顯示出來。

分析:要讓元件2與元件1同步,就讓元件1和2都去綁定父元件的狀態。也就是說讓兩個組件受控。資料的走向是,元件1將自身的資料提升到父層,並且保存在父層的狀態中。父層中的資料透過元件2中的props屬性傳遞到元件2中,並在視圖層進行綁定。

第一步先綁定元件


#
//在父层中的constructor中定义状态为一个空的message,this.state = {message:&#39;&#39;}
class Parent extends React.Component{
  constructor(...args){
   super(...args);
   this.state = {
    message:&#39;&#39;
   }
登入後複製


##然後在父元件中的改為



<Show onShow={this.state.message}/>
登入後複製


接著來我們進入元件中,給其內容綁定這個穿件來的onShow屬性。 元件變成



class Show extends React.Component{
  constructor(...args){
   super(...args);
  }
  render(){
   return <p>{this.props.onShow}</p>
  }
登入後複製


這樣元件2顯示層的資料已經綁定好了,接下來我們只要改變父親層狀態中的message的內容就可以使綁定的顯示層的內容跟著一起變化


將輸入層的狀態(數據)提升到父親組件中.下面是改寫後的元件1



class Input extends React.Component{
  constructor(...args){
    super(...args);
  }
   //将输入的内容更新到自身组件的状态中,并且将改变后的状态作为参数传递给该组件的一个自定义属性onInp()
  fn(ev){ 
   this.props.onInp(ev.target.value);
  }
  render(){
   //用onInput(注意react中采用驼峰写法和原生的略有不同)绑定fn()函数
   return <input type="text" onInput={this.fn.bind(this)} value={this.props.content}/>
  }
 }
登入後複製


#看到這裡可能會有一個問題:onInp()和content沒有啊?不要急,接著看


接著改寫父元件中的輸入層子元件1,


class Parent extends React.Component{
  constructor(...args){
   super(...args);
   this.state = {
    message:''
   };
  }
  //传进的text是其提升上来的状态,然后再更新父组件的状态
  fn(text){
   this.setState({
    message:text
   })
  }
  render(){
   return(
    

/* onInp就出现在这里,并绑定一个函数, 并且有一个content将父组件的状态同步到子组件中 */ <Show onShow={this.state.message}/>

); } }
登入後複製


寫完的程式碼是這樣的


// 父组
 class Parent extends React.Component{
  constructor(...args){
   super(...args);
   this.state = {
    message:''
   };
  }
  onInp(text){
   this.setState({
    message:text
   })
  }
  render(){
   return(
    

<Show onShow={this.state.message}/>

); } } //child-1 class Input extends React.Component{ constructor(...args){ super(...args); } fn(ev){ this.props.onInp(ev.target.value); } render(){ return } } //child-2 class Show extends React.Component{ constructor(...args){ super(...args); } render(){ return <p>{this.props.onShow}</p> } } //最后渲染出 ReactDOM.render( , document.getElementById('app') );
登入後複製


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

以上是React元件之間的通訊的實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

新一代光纖寬頻技術 ——50G PON 新一代光纖寬頻技術 ——50G PON Apr 20, 2024 pm 09:22 PM

上篇文章(連結),小棗君向大家介紹了寬頻技術從ISDN、xDSL到10GPON的發展歷程。今天,我們來聊聊即將到來的新一代光纖寬頻技術—50GPON。 █F5G和F5G-A介紹50GPON之前,先來談談F5G和F5G-A。 2020年2月,ETSI(歐洲電信標準化協會)推進了一套以10GPON+FTTR、Wi-Fi6、200G光傳送/匯聚、OXC等技術為基礎的固定通訊網路技術體系,並將其命名為F5G,也就是第五代固網通訊技術(The5thgenerationFixednetworks)。 F5G是固網

PHP、Vue和React:如何選擇最適合的前端框架? PHP、Vue和React:如何選擇最適合的前端框架? Mar 15, 2024 pm 05:48 PM

PHP、Vue和React:如何選擇最適合的前端框架?隨著互聯網技術的不斷發展,前端框架在Web開發中起著至關重要的作用。 PHP、Vue和React作為三種代表性的前端框架,每一種都具有其獨特的特徵和優勢。在選擇使用哪種前端框架時,開發人員需要根據專案需求、團隊技能和個人偏好做出明智的決策。本文將透過比較PHP、Vue和React這三種前端框架的特徵和使

無線滑鼠的發展史 無線滑鼠的發展史 Jun 12, 2024 pm 08:52 PM

原文標題:《無線滑鼠到底是怎麼做到無線的? 》無線滑鼠慢慢成了現在辦公電腦的標配,從此再也不用拖著長長的線跑來跑去了。可是,無線滑鼠是怎麼運作的呢?今天我們一起來學習No.1無線滑鼠的發展史你知道嗎,無線滑鼠現在也已經40歲了,1984年的時​​候,羅技研製了世界上第一款無線滑鼠,不過這個無線滑鼠採用紅外線作為訊號的載體,據說長得像下面圖片這個樣子,後面因為效能原因而宣告失敗。直到十年後的1994年,羅技終於研發成功了一個工作在27MHz的無線滑鼠,這個27MHz頻率也成了很長一段時間內,無線滑鼠

Java框架與前端React框架的整合 Java框架與前端React框架的整合 Jun 01, 2024 pm 03:16 PM

Java框架與React框架的整合:步驟:設定後端Java框架。建立專案結構。配置建置工具。建立React應用程式。編寫RESTAPI端點。配置通訊機制。實戰案例(SpringBoot+React):Java程式碼:定義RESTfulAPI控制器。 React程式碼:取得並顯示API回傳的資料。

寬頻上網技術簡史 寬頻上網技術簡史 Apr 16, 2024 am 09:00 AM

在現今這個數位時代,寬頻已經成為我們每個人、每個家庭的生活必需品。如果沒有它,我們會坐立難安、心緒不寧。那麼,你知道寬頻背後的技術原理嗎?從最早期的56k「貓」撥號,到現在的千兆城市、千兆家庭,我們的寬頻科技到底經歷了怎樣的改變?今天這篇文章,我們就來詳細了解一下—「寬頻的故事」。 █xDSL和ISDN下面這個介面,你看過嗎?我相信很多70後80後的小夥伴,肯定見過,非常熟悉。沒錯,這就是當年我們最初接觸網路時,進行「撥接上網」的介面。那還是20多年前,小棗君還在上大學的時候。為了上網,我

PHP實作Socket通訊的方法與技巧 PHP實作Socket通訊的方法與技巧 Mar 07, 2024 pm 02:06 PM

PHP是一種常用的開發語言,可以用來開發各種網頁應用程式。除了常見的HTTP請求和回應以外,PHP也支援透過Socket進行網路通信,實現更靈活和高效的資料互動。本文將介紹PHP如何實作Socket通訊的方法與技巧,並附上具體的程式碼範例。什麼是Socket通訊Socket是一種在網路中進行通訊的方法,可以在不同的電腦之間傳輸資料。透過S

長白山主峰可正常上網:吉林移動、中興通訊完成 2.6G + 700M 三載波聚合商用,峰值速率達 2.53Gbps 以上 長白山主峰可正常上網:吉林移動、中興通訊完成 2.6G + 700M 三載波聚合商用,峰值速率達 2.53Gbps 以上 Jul 25, 2024 pm 01:20 PM

7月25日訊息,吉林移動、中興通訊現已在長白山主峰完成基於2.6G頻段(100+60M)加700M頻段(30M)三載波聚合商用,現場測試峰值速率最高可達2.53Gbps以上。官方指出,長白山是中華十大名山之一,現為國家AAAAA級旅遊景區、世界地質公園、世界生物圈保護區、世界最佳自然保護地,2023年接待遊客數達到274.77萬人次,本次部署3CC將極大滿足用戶的網路需求。據介紹,吉林移動2024年初已經率先完成2.6G(100+60M)加4.9G(100M)頻段三載波組網載波聚合試點,下載峰值

華為星閃應用程式今年將首推家居場景,海爾星閃彩電第三季發布 華為星閃應用程式今年將首推家居場景,海爾星閃彩電第三季發布 Mar 17, 2024 am 10:00 AM

本站3月16日訊息,星閃(NearLink)是中國原生的新一代無線短距通訊技術,與傳統短距傳輸技術方案相比,星閃在功耗、速度、覆蓋範圍和連接性能全面領先。本站查詢發現,除了華為Mate60系列、Pocket2、MatePadPro13.2/11(2024)、第三代HUAWEIM-Pencil,星閃技術目前已落地無線滑鼠、車鑰匙、無線耳機等終端設備。 《科創板日報》稱,華為星閃今年將以智慧家庭為主要落地場景,目前已與海爾產品進行技術適配,預計搭載星閃技術的海爾彩電將在今年三季正式推出。與傳統短距傳

See all articles