摘要:四總結(jié)上面一系列的操作最終的結(jié)果都需要用來反應(yīng)出來,所以關(guān)鍵點是如何在中使用來動態(tài)生成接下來的改進(jìn)實現(xiàn)可以滑動的標(biāo)簽頁
一、首先是Showcase
See the Pen react-tabs by Wang Chao (@charleyw) on CodePen.
二、如何實現(xiàn)既然用React寫,那么它就必然是一個組件,首先考慮你怎么使用這個組件,也就是這個組件的接口是怎么樣的。
這個TabsControl作為父組件,它來控制Tab的如何切換,Tab是用來包裹真正要顯示的內(nèi)容的,它的name屬性是這個標(biāo)簽頁的名字,會被顯示在標(biāo)簽頁的標(biāo)題欄上。
三、創(chuàng)建基本元素按照之前的想法,我們用Tab定義了很多個標(biāo)簽頁,我們需要根據(jù)這些定義生成標(biāo)簽頁的標(biāo)題欄和內(nèi)容。
1. 遍歷this.props.children動態(tài)生成標(biāo)題欄this.props.children是React內(nèi)建的一個屬性,用來獲取組件的子元素。因為子元素有可能是Object或者Array,所以React提供了一些處理children的輔助方法用來遍歷:React.Children.map
那么動態(tài)生成標(biāo)題的代碼可能是這樣子的:
React.Children.map(this.props.children, (element, index) => { return (2. 再用同樣方法生成標(biāo)簽頁內(nèi)容{element.props.name})
React.Children.map(this.props.children, element => { return (element) })
組合起來就是TabsControl的實現(xiàn):
let TabsControl = React.createClass({ render: function () { let that = this; let {baseWidth} = this.props; let childrenLength = this.props.children.length; return () } });{React.Children.map(this.props.children, element => { return (element) })}
加上一些css就能看到一個標(biāo)簽頁的雛形了。
三、實現(xiàn)標(biāo)簽頁切換這里要出現(xiàn)React最重要的概念了state,state是一個Javascript的Object,它是用來表示組件的當(dāng)前狀態(tài)的,如果用TabsControl舉例的話,它的state可以是當(dāng)前處于激活狀態(tài)的標(biāo)簽頁編號(當(dāng)然,如果你想的話也可以保存標(biāo)簽頁的內(nèi)容)。
React提供了一個方法setState()讓你可以改變state的值。每次調(diào)用setState()都會觸發(fā)組件的render(),也就是說會把組件所代表的DOM更新到state所代表的狀態(tài)。
所以實現(xiàn)切換的關(guān)鍵如下:
state保存當(dāng)前處于激活狀態(tài)的標(biāo)簽頁的編號
點擊標(biāo)題的時候調(diào)用setState()更新激活的標(biāo)簽頁編號
render()的時候,在遍歷this.props.children的時候把編號與state中編號一致的元素標(biāo)記為active
用css將非active的元素隱藏起來
所以代碼是這樣的:
let TabsControl = React.createClass({ getInitialState: function(){ return {currentIndex: 0} }, getTitleItemCssClasses: function(index){ return index === this.state.currentIndex ? "tab-title-item active" : "tab-title-item"; }, getContentItemCssClasses: function(index){ return index === this.state.currentIndex ? "tab-content-item active" : "tab-content-item"; }, render: function(){ let that = this; let {baseWidth} = this.props; let childrenLength = this.props.children.length; return () } });{React.Children.map(this.props.children, (element, index) => { return ({element}) })}
getInitialState:是組件的初始化狀態(tài),默認(rèn)是第一個標(biāo)簽頁處于激活狀態(tài)。
getTitleItemCssClasses:判斷當(dāng)前標(biāo)簽和state中保存的標(biāo)簽編號是否一直,是則標(biāo)識為active。
getContentItemCssClasses:同上。
onClick={() => {this.setState({currentIndex: index})}}:標(biāo)簽頁標(biāo)題綁定了點擊事件,每次點擊都會更新state保存的標(biāo)簽頁編號,然后觸發(fā)render()方法重繪標(biāo)簽頁。
上面一系列的操作最終的結(jié)果都需要用render()來反應(yīng)出來,所以關(guān)鍵點是如何在render()中使用state來動態(tài)生成DOM.
接下來的改進(jìn)實現(xiàn)可以滑動的標(biāo)簽頁
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91584.html
摘要:四總結(jié)上面一系列的操作最終的結(jié)果都需要用來反應(yīng)出來,所以關(guān)鍵點是如何在中使用來動態(tài)生成接下來的改進(jìn)實現(xiàn)可以滑動的標(biāo)簽頁 一、首先是Showcase See the Pen react-tabs by Wang Chao (@charleyw) on CodePen. 二、如何實現(xiàn) 既然用React寫,那么它就必然是一個組件,首先考慮你怎么使用這個組件,也就是這個組件的接口是怎么樣的。 ...
摘要:官方文檔中文文檔基本使用注意一定要在根目錄的中聲明,要不然點擊任何鏈接都無法跳轉(zhuǎn)。官方文檔中文文檔簡單的來說,每一次的修改狀態(tài)都需要觸發(fā),然而其實項目中我現(xiàn)在還沒用到修改數(shù)據(jù)。。。 學(xué)習(xí) React 的過程中實現(xiàn)了一個個人主頁,沒有復(fù)雜的實現(xiàn)和操作,適合入門 ~ 原文地址:https://github.com/axuebin/react-blog/issues/17 這個項目其實功能...
摘要:最新一直在看關(guān)于和路由這塊的知識,最終發(fā)現(xiàn)這些路由框架的模塊功能的實現(xiàn)都是基于瀏覽器原生路由的。在瀏覽器中實現(xiàn)前端路由主要有兩種方式一個是我們常用的,另一個是提供的。該對象的和分別表示的各個部分,它們因此被稱為分解屬性。 最新一直在看關(guān)于 Vue 和 React 路由這塊的知識,最終發(fā)現(xiàn)這些路由框架的模塊功能的實現(xiàn)都是基于瀏覽器原生路由 API?的。本著追根溯源的初心,于是就想著將瀏覽...
摘要:最新一直在看關(guān)于和路由這塊的知識,最終發(fā)現(xiàn)這些路由框架的模塊功能的實現(xiàn)都是基于瀏覽器原生路由的。在瀏覽器中實現(xiàn)前端路由主要有兩種方式一個是我們常用的,另一個是提供的。該對象的和分別表示的各個部分,它們因此被稱為分解屬性。 最新一直在看關(guān)于 Vue 和 React 路由這塊的知識,最終發(fā)現(xiàn)這些路由框架的模塊功能的實現(xiàn)都是基于瀏覽器原生路由 API?的。本著追根溯源的初心,于是就想著將瀏覽...
閱讀 1111·2021-11-24 10:24
閱讀 2596·2021-11-22 13:54
閱讀 1003·2021-09-24 09:55
閱讀 3606·2019-08-30 15:54
閱讀 1322·2019-08-30 15:44
閱讀 1098·2019-08-30 14:23
閱讀 3206·2019-08-29 13:45
閱讀 1286·2019-08-29 11:19