react的函數有哪些? react函數的詳細解析(附實例)
這篇文章主要講述的就是關於react該如何學習的介紹,現在讓我們一起來看文章的正文內容吧
React根本上其實就是一個JavaScript函式庫。
它體現了前後分離的思想,將部分組裝頁面的工作轉交給瀏覽器來完成;不像JSP文件,頁面的佈局和填入數據是在伺服器完成後發送給瀏覽器的的。
這樣做的好處自然有很多:首先,React將DOM&JavaScript封裝成模組(元件),這些元件的可重複使用性很強,不僅如此,元件也可以讓測試和關注分離變得簡單。其次,當資料變化的時候,React能夠自動更新使用者介面,並且僅更新需要更新的部分。
核心函數1:render
這個函數的功能就是提供一個模組,它就像是樂高玩具的一塊積木,用來組裝頁面。
簡單範例:(先給的是html程式碼,後面給的是JSX程式碼。JSX就是JavaScript XML的意思)
<p id="container" class="firstContainer"> <p>replaced</p> </p>/*************************************************/ReactDOM.render( <p>Hello, world!</p>, document.getElementsByClassName('firstContainer')[0] );
可以看到class 為firstContainer 的p的內容被替換掉了,替換成了我們在render中寫入的程式碼:hello world!
另外document.getElementsByClassName('firstContainer')[0]可以替換成任何原生的JavaScript獲取**單獨某一個(一定是一個Node,因此如果你使用document.getElementsByClassName這樣的方法必須要加上[n])**DOM元素的方法:document.getElementById或document.getElementsByTagName等都可以。
更複雜一點的例子,我們可以來將這裡的<p>Hello, world!</p>
擴充。
<p id="container" class="firstContainer"> <p>replaced</p> </p>/*************************************************/var name = "Emily"; ReactDOM.render( <p> { (function(){ return <p>Hello, {name}!</p> })() } </p>, document.getElementById('container') );
我們可以看到JSX語法的神奇之處了,在程式碼中,JS和DOM可以說是混雜在一起的。而JSX 的基本語法規則:遇到 HTML 標籤(以 < 開頭),就用 HTML 規則解析;遇到程式碼區塊(以 { 開頭),就用 JavaScript 規則解析。
核心函數2:React.createClass
這個函數允許我們自己定義需要的元件,定義好的元件可以作為像p這樣的標籤一樣,直接應用於render函數中。
一個簡單的栗子:
<p id="container" class="firstContainer"> <p>replaced</p> </p>/*************************************************/var HelloWorldBox = React.createClass({ render: function() { return ( <p className="helloWorldBox"> Hello, world! I am a helloWorldBox. </p> ); } }); ReactDOM.render( <HelloWorldBox />, document.getElementById('container') );
在這個栗子裡,HelloWorldBox就是一個最簡單的元件。
關於這個元件,我們還可以獲得更多資訊。例如,使用props
(實例來自React官網)
<p id="container" class="firstContainer"> <p>replaced</p> </p>/*************************************************/var Comment = React.createClass({ render: function() { return ( <p className="comment"> <h2 className="commentAuthor"> {this.props.author} </h2> {this.props.children} </p> ); } });var CommentList = React.createClass({ render: function() { return ( <p className="commentList"> <Comment author="Pete Hunt">This is one comment</Comment> <Comment author="Jordan Walke">This is *another* comment</Comment> </p> ); } }); ReactDOM.render( <CommentList />, document.getElementById('container') );
在這個栗子中,我們使用React.createClass方法建立了兩個元件,我們可以看到,在元件CommentList中,嵌套了Comment:也就是說,CommentList是由多個Comment組成的。我們在CommentList中為Comment定義了一個屬性:author。那麼,在Comment元件中,就可以透過{this.props.author}讀到這個屬性,而透過{this.props.children},則可以讀到這個元件的子節點。
存取外部數據:
<p id="container" class="firstContainer"> <p>replaced</p> </p>/*************************************************/var Comment = React.createClass({ render: function() { return ( <p className="comment"> <h2 className="commentAuthor"> {this.props.author} </h2> {this.props.children} </p> ); } });var names = ['Alice', 'Emily', 'Kate']; ReactDOM.render( <p> { names.map(function (name) { return <Comment author={name}>is an author~</Comment> }) } </p>, document.getElementById('container') );
在這裡,數組names是外部數據,我們透過建立元件,將這些數據嵌入了網頁的DOM中。
元件state
每個元件都有一個屬性:state,開發者可以透過呼叫this.setState()來改變元件的狀態。當狀態更新之後,元件就會重新渲染自己。 state和props都是一個元件的特性,但是不同的是,props是不變的,但是state是可以改變的。
getInitialState()可以設定元件的初始化狀態,而這個函數在元件的生命週期中只執行一次。
更新狀態:
註:componentDidMount函數是元件的生命週期函數,它是一個在元件被渲染的時候React自動呼叫的方法,後面會詳細講到。
var CommentBox = React.createClass({ getInitialState: function() { return {data: []}; }, componentDidMount: function() { $.ajax({ url: this.props.url, dataType: 'json', success: function(data) { this.setState({data: data}); }.bind(this), error: function(xhr, status, err) { console.error(this.props.url, status, err.toString()); }.bind(this) }); }, render: function() { return ( <p className="commentBox"> <h1>Comments</h1> <CommentList data={this.state.data} /> </p> ); } });
這個栗子中,我們透過ajax取得數據,並透過函數this.setState將取得的數據設定為this.state.data。然後,在CommentList中,設定data={this.state.data},就可以將從伺服器取得的資料顯示出來。 (想看更多就到PHP中文網React參考手冊欄位學習)
元件的生命週期
元件的生命週期分為以下三種:
Mounting:已插入真實DOM
#Updating:正在重新渲染
- ##Unmounting:已移出真實DOM
componentWillMount()componentDidMount()componentWillUpdate(object nextProps, object nextState)componentDidUpdate(object prevProps, object prevState)componentWillUnmount()另外還有兩個特殊狀態的處理函數:
componentWillReceiveProps(object nextProps):已加载组件收到新的参数时调用shouldComponentUpdate(object nextProps, object nextState):组件判断是否重新渲染时调用下面這個栗子來自於阮一峰大神的博客:
var Hello = React.createClass({ getInitialState: function () { return { opacity: 1.0 }; }, componentDidMount: function () { this.timer = setInterval(function () { var opacity = this.state.opacity; opacity -= .05; if (opacity < 0.1) { opacity = 1.0; } this.setState({ opacity: opacity }); }.bind(this), 100); }, render: function () { return ( <p style={{opacity: this.state.opacity}}> Hello {this.props.name} </p> ); } }); ReactDOM.render( <Hello name="world"/>, document.body );componentDidMount函數在元件插入真實DOM以後調用,在這個函數裡,我們設定了一個定時器,每100毫秒改變一次透明度,直到元件完全透明後,將透明度再設定成1(初始的透明度設定為1)。這樣,這個元件聚會不停在被渲染。這樣,我們就在頁面上得到了一個不停閃爍的hello world字串。如果我們寫函數:
componentDidUpdate:function(){ console.log("did update"); }我們就可以在控制台看到不斷的輸出。
React根本上其實就是一個JavaScript函式庫。
它體現了前後分離的思想,將部分組裝頁面的工作轉交給瀏覽器來完成;不像JSP文件,頁面的佈局和填入數據是在伺服器完成後發送給瀏覽器的的。
這樣做的好處自然有很多:首先,React將DOM&JavaScript封裝成模組(元件),這些元件的可重複使用性很強,不僅如此,元件也可以讓測試和關注分離變得簡單。其次,當資料變化的時候,React能夠自動更新使用者介面,並且僅更新需要更新的部分。
這篇文章到這就結束了(想看更多就到PHP中文網React使用手冊欄位中學習),有問題的可以在下方留言提問。
以上是react的函數有哪些? react函數的詳細解析(附實例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undress AI Tool
免費脫衣圖片

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

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

Stock Market GPT
人工智慧支援投資研究,做出更明智的決策

熱門文章

熱工具

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

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

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

Dreamweaver CS6
視覺化網頁開發工具

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

Vue.js和React各有優勢:Vue.js適用於小型應用和快速開發,React適合大型應用和復雜狀態管理。 1.Vue.js通過響應式系統實現自動更新,適用於小型應用。 2.React使用虛擬DOM和diff算法,適合大型和復雜應用。選擇框架時需考慮項目需求和團隊技術棧。

Netflix選擇React來構建其用戶界面,因為React的組件化設計和虛擬DOM機制能夠高效處理複雜界面和頻繁更新。 1)組件化設計讓Netflix將界面分解成可管理的小組件,提高了開發效率和代碼可維護性。 2)虛擬DOM機制通過最小化DOM操作,確保了Netflix用戶界面的流暢性和高性能。

reactisafrontendlibrary,focusedonBuildingUserInterfaces.itmanagesuistateandupdatesefficefited avelyuseVirusity diftualdom,and internactSwithBackendServIcesViaApisforDatahandling,butdoesnotprocessorcorsorsorstoredordordordoredairself。

Vue.js和React的未來趨勢和預測分別是:1)Vue.js將在企業級應用中廣泛應用,並在服務端渲染和靜態站點生成方面有突破;2)React將在服務器組件和數據獲取方面創新,並進一步優化並發模式。

在React中包含CSS的方法有五種:1.使用內聯樣式,簡單但不利於復用和維護;2.使用CSS文件,通過導入實現,利於組織但可能導致衝突;3.使用CSSModules,避免全局衝突但需配置;4.使用StyledComponents,利用JavaScript動態生成樣式但需依賴庫;5.使用Sass或Less,提供更多功能但增加構建複雜性。

Vue.js適合小型到中型項目,React適合大型項目和復雜應用場景。 1)Vue.js易於上手,適用於快速原型開發和小型應用。 2)React在處理複雜狀態管理和性能優化方面更有優勢,適合大型項目。

是的,ReactApplicationsCanbEseo-FrylylywithProperStratecies.1)用戶 - 插圖(SSR)withToolslikenext.jstogenate.jstogenate fullhtmlforindexing.2)enasleStaticsiteSitegeneration(ssg)

React和Bootstrap可以無縫集成來提升用戶界面設計。 1)安裝依賴包:npminstallbootstrapreact-bootstrap。 2)導入CSS文件:import'bootstrap/dist/css/bootstrap.min.css'。 3)使用Bootstrap組件,如按鈕和導航欄。通過這種結合,開發者可以利用React的靈活性和Bootstrap的樣式庫,創建美觀且高效的用戶界面。
