React Native07 - 組件的聲明周期、組件的屬性和狀態(tài)、獲取真實(shí)的DOM節(jié)點(diǎn)

前言

本篇的重點(diǎn)如下

  • 組件的生命周期
  • 組件的屬性和狀態(tài)
  • 獲取真實(shí)的DOM節(jié)點(diǎn)

一、組件的生命周期

  1. ReactNative組件的聲明周期大致上可以劃分為實(shí)例化階段、存在階段、銷毀階段

  2. 最常用的為實(shí)例化階段,該階段就是組件的構(gòu)建、展示時(shí)期,需要我們根據(jù)幾個(gè)函數(shù)的調(diào)用過程,控制好組件的展示和邏輯的處理

  3. 實(shí)例化階段函數(shù)功能分析
    1) getDefaultProps
    a. 該函數(shù)用于初始化一些默認(rèn)的屬性,通常會(huì)將固定的內(nèi)容放在這個(gè)函數(shù)中進(jìn)行賦值
    
     b. 在組件中,可以利用this.props獲取這里屬性,由于組件初始化后,再次使用該組件不會(huì)調(diào)用getDefaultProps函數(shù),所以組件自己不可以自己修改props,只可有其他組件調(diào)用它時(shí)在外部修改
    
     c. 使用組件時(shí),可以自定義屬性,在該組件內(nèi)部使用this.props.xxx獲取到
    
    2) getInitialState
    a. 該函數(shù)是用于對(duì)組件的一些狀態(tài)進(jìn)行初始化,由于該函數(shù)不同于getDefaultProps,在以后的過程中,會(huì)再次調(diào)用,所以可以將控制控件的狀態(tài)的一些變量放在這里初始化,如控件上顯示的文字,可以通過this.state來獲取值,通過this.setState來修改state值,比如
    
          this.setState({
              activePage: activePage,                     
          });
    
    b. 一旦調(diào)用了this.setState方法,組件一定會(huì)調(diào)用render方法,對(duì)組件再次進(jìn)行渲染,不過,react框架會(huì)自動(dòng)根據(jù)DOM的狀態(tài)來判斷是否需要真正的渲染
    
    3) componentWillMount
     在組件將要被加載在視圖之前調(diào)用,功能相對(duì)較少
    
    4) render(每次頁面發(fā)生變化都會(huì)調(diào)用該函數(shù))
     a. render是一個(gè)組件中必須有的方法,本質(zhì)上是一個(gè)函數(shù),并返回JSX或其他組件來構(gòu)成DOM,和Android的XML布局類似,只能返回一個(gè)頂級(jí)元素
    
     b. 在render函數(shù)中,只可通過this.state和this.props來訪問在之前函數(shù)中初始化的數(shù)據(jù)值
    
    5) componentDidMount
     a. 在調(diào)用了render方法后,組件加載成功并被成功渲染出來以后,所要執(zhí)行的后續(xù)操作,一般會(huì)在這個(gè)函數(shù)中處理網(wǎng)絡(luò)請(qǐng)求等加載數(shù)據(jù)的操作
    
     b. 因?yàn)閁I已經(jīng)成功被渲染出來,所以放在這個(gè)函數(shù)里進(jìn)行請(qǐng)求操作,不會(huì)出現(xiàn)UI上的操作
    
  4. 存在期階段函數(shù)功能分析

    1) componentWillReceiveProps
    已加載組件收到新的參數(shù)時(shí)調(diào)用
    
    2) shouldComponentUpdate
    一般用于優(yōu)化,可以返回false或true來控制是否進(jìn)行渲染
    
    3) componentWillUpdate
    組件刷新前調(diào)用,類似componentWillMount
    
    4) componentDidUpdate
    組件更新結(jié)束之后執(zhí)行,在初始化render時(shí)不執(zhí)行
    
  5. 銷毀期階段函數(shù)功能分析

    componentWillUnmount
     用于清理一些無用的內(nèi)容,如:點(diǎn)擊事件Listener
    
  6. 注意

    a. this.props表示那些一旦定義,就不再改變的特性
    
    b. this.state是會(huì)隨著用戶互動(dòng)而產(chǎn)生變化的特性
    

二、組件的屬性和狀態(tài)

  1. 屬性和狀態(tài)其實(shí)在生命周期中我們已經(jīng)提到,但由于他真的特別重要,在這里我們單獨(dú)再學(xué)習(xí)一下。

  2. 組件的屬性

    1) 使用getDefaultProps函數(shù)來設(shè)置組件的屬性
    var myView = React.createClass({
    
      //通過getDefaultProps設(shè)置組件的屬性對(duì)象
      getDefaultProps(){
    
         return {
    
            props1Name:"",
                 
         }
      },
    
      render(){
    
          return (
             <View>
                <Text>{{this.props.props1Name}}</Text>
             </View>
          )
      }
    
    });
    
    屬性一旦定義,就不再改變,通過this.props.props1Name來獲取getDefaultProps中定義的屬性對(duì)象的值
    
2) 通過自定義屬性來設(shè)置組件的屬性
       //自定義組件
       var MyView = React.createClass({

             render(){

                 return(

                    <View>
                       <Text>{{this.props.props1Name}}</Text>
                    </View>

                 )
             }

          });

       //使用自定義組件myView時(shí)給組件設(shè)置自定義的屬性,也可以通過this.props來獲取到該值
       var TestView = React.createClass({

            render(){

               return(
                  {/*給myView設(shè)置自定義屬性*/}
                  <MyView props1Name="test"></MyView>
                  }
               )
            }

       })

       AppRegistry.registerComponent('demo1', () => TestView);
      
#### 3. 組件的狀態(tài)

       var MyView = React.createClass({

         //通過getInitialState設(shè)置組件的狀態(tài)對(duì)象
         getInitialState(){

             return {

                value:"",
               
             }
         },

         render(){

             <View>
                <Text>{{this.state.value}}</Text>
             </View>
         }

      });

      狀態(tài)定義過后,可以通過this.state.value來獲取getInitialState中定義的狀態(tài)對(duì)象的值,也可以通過this.setState({ value:"test", })來修改狀態(tài)值

三、獲取真實(shí)的DOM節(jié)點(diǎn)

1. JSX

    <TextInput ref="myTextInput">

2. JS

    this.refs.myTextInput 

四、聲明周期和

獲取DOM節(jié)點(diǎn)的案例和注釋見Demo1

11.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,572評(píng)論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,071評(píng)論 3 414
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,409評(píng)論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,569評(píng)論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,360評(píng)論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 54,895評(píng)論 1 321
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,979評(píng)論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,123評(píng)論 0 286
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,643評(píng)論 1 333
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,559評(píng)論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,742評(píng)論 1 369
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,250評(píng)論 5 356
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 43,981評(píng)論 3 346
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,363評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,622評(píng)論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,354評(píng)論 3 390
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,707評(píng)論 2 370

推薦閱讀更多精彩內(nèi)容