react無狀態寫法是什麼
react無狀態寫入法是“{props.xxx}”,其無狀態元件主要用來定義模板,接收來自父元件props傳遞過來的數據,並使用“{props.xxx}”的表達式把props塞到模板裡面。
本文操作環境:Windows7系統、react17.0.1、Dell G3。
react無狀態寫法是什麼?
React中無狀態元件和有狀態元件的寫法以及區別
React中的元件主要分為無狀態元件和有狀態元件兩類。
1,無狀態元件主要用來定義模板,接收來自父元件props傳遞過來的數據,使用{props.xxx}的表達式把props塞到模板裡面。無狀態組件應該保持模板的純粹性,以便於組件重複使用。建立無狀態元件如下:
var Header = (props) = ( <p>{props.xxx}</p> ); export default Header
2,有狀態元件主要用來定義互動邏輯和業務資料(如果用了Redux,可以把業務資料抽離出去統一管理),使用{this .state.xxx}的表達式把業務資料掛載到容器元件的實例上(有狀態元件也可以叫做容器元件,無狀態元件也可以叫做展示元件),然後傳遞props到展示元件,展示元件接收到props,把props塞到模板裡面。建立有狀態元件如下:
class Home extends React.Component { constructor(props) { super(props); }; render() { return ( <header></header> //也可以写成<header></header> ) } } export default Home
這個是官方預設的寫法,在建構函式裡面預設要傳遞一個參數進去,並且要呼叫super()方法,來取得子類別的實例。但是比較疑惑的地方是為什麼要傳遞這些參數,傳遞這些參數有什麼用呢?
因為從render()裡面的元件來看,建構子不傳遞參數也可以取得到元件實例上的props屬性。如下:
class Home extends React.Component { constructor() { super(); }; render (){ return( <p> <header></header> </p> ); }; }; class Header extends React.Component { constructor() { super(); }; render() { return ( <p>{this.props.name}</p> //构造函数中并没有传递props属性,这里通过{this.props.name}依然获取到了值 ); }; };
這個比較好理解,因為render()方法是子元件原型上的方法,取得實例屬性的時候要透過this來訪問,如果去掉this就取得不到了。
那問題來了,如果我們要在建構子中存取props改怎麼辦呢?此時,我們就要在constructor建構函式中傳遞一個props參數,這樣就可以存取到子元件實例上的props屬性了。如下:
class Header extends React.Component { constructor(props) { super(); this.name = props.name; //获取到子组件实例上的props.name属性,赋值给实例属性name }; render() { return ( <p>{this.name}</p> ); }; };
還有一個問題,super(props)方法為什麼也要傳遞一個props屬性呢?看下面的範例:
class Header extends React.Component { constructor(props) { super(props); this.state = { nameOne: props.name, nameTwo: this.props.name //super()方法中传递了props属性,this.props才可以获取到name属性 } }; render() { return ( <p>{this.state.nameOne}{this.state.nameTwo}</p> ); }; };
其實,props.name和this.props.name的值都是一樣的,但它兩個還是有差別的,props.name中這個props就是子元件的屬性props ,但是this.props.name中的這個props卻不是子元件的屬性props,雖然值都是一樣的,這個props其實在呼叫super方法的時候被傳遞到了Component這個父類別中去了,所以this.props .name取得到的是Component父類別中的props屬性。看下React的原始碼:
發現沒,子類別super方法把props參數傳遞給了父類別Component,Component把props參數掛載到它的實例屬性props上了。所以,你只有在super方法中傳遞props參數,在建構函式裡才能用this,props.xxx
#如果super方法中不傳遞props參數,取得this.props.name的值就會報錯。取得this.props顯示為undifined:如下:
class Header extends React.Component { constructor(props) { super(); this.state = { nameOne: this.props.name, nameTwo: this.props }; console.log(this.props.name); //报错 console.log(this.props); //undifined }; render() { return ( <p>{this.state.nameOne}{this.state.nameTwo}</p> ); }; };
這種寫法本質是給子元件Header的實例屬性state.nameOne和state.nameTwo賦值了一個子元件Header的實例屬性props,簡單來說,就是Header子元件創建了一個state屬性,然後又把自己的props屬性賦值給了自己的state屬性。
為什麼this.props要印出undefined?因為props是呼叫子元件的時候傳入的參數,所以在建構函式內部是存取不到props的,那麼對於this.props.name來說,毫無疑問肯定報錯。
所以,對於與建構函式中的props參數和super中的props參數來說,如果你不在建構函式中用this.props和props,完全可以不用傳參。反之就要傳參。但是對於this.props和props來說取得到的值都是一樣的,所以寫哪個都可以。但是官方文檔上是兩個參數都有寫。所以為了嚴謹,還是都寫上吧。
但是,我個人還是喜歡這樣的寫法。
constructor(props) { super(props); this.state = { name: props.name } };
不加this的是value,加了this的是key。
React中的元件主要分為無狀態元件和有狀態元件兩類。
1,無狀態元件主要用來定義模板,接收來自父元件props傳遞過來的數據,使用{props.xxx}的表達式把props塞到模板裡面。無狀態組件應該保持模板的純粹性,以便於組件重複使用。建立無狀態元件如下:
var Header = (props) = ( <p>{props.xxx}</p> ); export default Header
2,有狀態元件主要用來定義互動邏輯和業務資料(如果用了Redux,可以把業務資料抽離出去統一管理),使用{this .state.xxx}的表達式把業務資料掛載到容器元件的實例上(有狀態元件也可以叫做容器元件,無狀態元件也可以叫做展示元件),然後傳遞props到展示元件,展示元件接收到props,把props塞到模板裡面。建立有狀態元件如下:
class Home extends React.Component { constructor(props) { super(props); }; render() { return ( <header></header> //也可以写成<header></header> ) } } export default Home
這個是官方預設的寫法,在建構函式裡面預設要傳遞一個參數進去,並且要呼叫super()方法,來取得子類別的實例。但是比較疑惑的地方是為什麼要傳遞這些參數,傳遞這些參數有什麼用呢?
因為從render()裡面的元件來看,建構子不傳遞參數也可以取得到元件實例上的props屬性。如下:
class Home extends React.Component { constructor() { super(); }; render (){ return( <p> <header></header> </p> ); }; }; class Header extends React.Component { constructor() { super(); }; render() { return ( <p>{this.props.name}</p> //构造函数中并没有传递props属性,这里通过{this.props.name}依然获取到了值 ); }; };
這個比較好理解,因為render()方法是子元件原型上的方法,取得實例屬性的時候要透過this來訪問,如果去掉this就取得不到了。
那問題來了,如果我們要在建構子中存取props改怎麼辦呢?此時,我們就要在constructor建構函式中傳遞一個props參數,這樣就可以存取到子元件實例上的props屬性了。如下:
class Header extends React.Component { constructor(props) { super(); this.name = props.name; //获取到子组件实例上的props.name属性,赋值给实例属性name }; render() { return ( <p>{this.name}</p> ); }; };
還有一個問題,super(props)方法為什麼也要傳遞一個props屬性呢?看下面的範例:
class Header extends React.Component { constructor(props) { super(props); this.state = { nameOne: props.name, nameTwo: this.props.name //super()方法中传递了props属性,this.props才可以获取到name属性 } }; render() { return ( <p>{this.state.nameOne}{this.state.nameTwo}</p> ); }; };
其實,props.name和this.props.name的值都是一樣的,但它兩個還是有差別的,props.name中這個props就是子元件的屬性props ,但是this.props.name中的這個props卻不是子元件的屬性props,雖然值都是一樣的,這個props其實在呼叫super方法的時候被傳遞到了Component這個父類別中去了,所以this.props .name取得到的是Component父類別中的props屬性。看下React的原始碼:
發現沒,子類別super方法把props參數傳遞給了父類別Component,Component把props參數掛載到它的實例屬性props上了。所以,你只有在super方法中傳遞props參數,在建構函式裡才能用this,props.xxx
#如果super方法中不傳遞props參數,取得this.props.name的值就會報錯。取得this.props顯示為undifined:如下:
class Header extends React.Component { constructor(props) { super(); this.state = { nameOne: this.props.name, nameTwo: this.props }; console.log(this.props.name); //报错 console.log(this.props); //undifined }; render() { return ( <p>{this.state.nameOne}{this.state.nameTwo}</p> ); }; };
這種寫法本質是給子元件Header的實例屬性state.nameOne和state.nameTwo賦值了一個子元件Header的實例屬性props,簡單來說,就是Header子元件創建了一個state屬性,然後又把自己的props屬性賦值給了自己的state屬性。
為什麼this.props要印出undefined?因為props是呼叫子元件的時候傳入的參數,所以在建構函式內部是存取不到props的,那麼對於this.props.name來說,毫無疑問肯定報錯。
所以,對於與建構函式中的props參數和super中的props參數來說,如果你不在建構函式中用this.props和props,完全可以不用傳參。反之就要傳參。但是對於this.props和props來說取得到的值都是一樣的,所以寫哪個都可以。但是官方文檔上是兩個參數都有寫。所以為了嚴謹,還是都寫上吧。
但是,我個人還是喜歡這樣的寫法。
constructor(props) { super(props); this.state = { name: props.name } };
不加this的是value,加了this的是key。
推薦學習:《react影片教學》
以上是react無狀態寫法是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

React前後端分離指南:如何實現前後端的解耦和獨立部署,需要具體程式碼範例在當今的Web開發環境中,前後端分離已經成為一種趨勢。透過將前端和後端程式碼分開,可以讓開發工作更加靈活、高效,並且方便進行團隊協作。本文將介紹如何使用React實現前後端分離,從而實現解耦和獨立部署的目標。首先,我們要先理解什麼是前後端分離。傳統的Web開發模式中,前端和後端是耦合在

如何利用React和RabbitMQ建立可靠的訊息傳遞應用程式引言:現代化的應用程式需要支援可靠的訊息傳遞,以實現即時更新和資料同步等功能。 React是一種流行的JavaScript庫,用於建立使用者介面,而RabbitMQ是一種可靠的訊息傳遞中間件。本文將介紹如何結合React和RabbitMQ建立可靠的訊息傳遞應用,並提供具體的程式碼範例。 RabbitMQ概述:

ReactRouter使用指南:如何實現前端路由控制隨著單頁應用的流行,前端路由成為了一個不可忽視的重要部分。 ReactRouter作為React生態系統中最受歡迎的路由庫,提供了豐富的功能和易用的API,使得前端路由的實作變得非常簡單和靈活。本文將介紹ReactRouter的使用方法,並提供一些具體的程式碼範例。安裝ReactRouter首先,我們需要

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

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

如何利用React開發一個響應式的後台管理系統隨著互聯網的快速發展,越來越多的企業和組織需要一個高效、靈活、易於管理的後台管理系統來處理日常的操作事務。 React作為目前最受歡迎的JavaScript庫之一,提供了一種簡潔、高效和可維護的方式來建立使用者介面。本文將介紹如何利用React開發一個響應式的後台管理系統,並給出具體的程式碼範例。建立React專案首先

Vue.js適合中小型項目和快速迭代,React適用於大型複雜應用。 1)Vue.js易於上手,適用於團隊經驗不足或項目規模較小的情況。 2)React的生態系統更豐富,適合有高性能需求和復雜功能需求的項目。

react有事件處理函數、useEffect和useCallback、高階元件等等閉包。詳細介紹:1、事件處理函數閉包:在React中,當我們在元件中定義事件處理函數時,函數會形成一個閉包,可以存取元件作用域內的狀態和屬性。這樣可以在事件處理函數中使用元件的狀態和屬性,實現互動邏輯;2、useEffect和useCallback中的閉包等等。
