亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

React State狀態(tài)與生命周期的實現方法

 更新時間:2021年03月23日 10:08:41   作者:一枚小棋子  
這篇文章主要介紹了React State狀態(tài)與生命周期的實現方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

一、實現組件的方法:

組件名稱首字母必須大寫

1.通過JS函數方式實現組件

<div id="app"></div>
<script type="text/babel">
  var ReactDiv = document.getElementById('app');
  function GetReactComp(){
    return <p>我是react組件</p>
  }
  const hellocomp = < GetReactComp />  //首字母大寫
  const reactSpan = (
    <span>
      { hellocomp }
    </span>
  )
  ReactDOM.render(reactSpan,ReactDiv)
</script>

2.通過ES6 class實現組件

<div id="class"></div>
<script type="text/babel">
  var reactDiv1=document.getElementById('class');
  //定義類組件
  class MyReactComp extends React.Component{
    render(){
      return (
        <h2>類組件</h2>
      )
    }
  }
  //使用類組件
  const testDiv = (
    <div>{<MyReactComp/>}</div>
  )
	//掛載
  ReactDOM.render(testDiv,reactDiv1)
</script>

二、props組件傳值

React對props有嚴格的保護機制,一旦給定值,在組件中不允許被改變。

<div id="app"></div>
<script type="text/babel">
  var reactDiv = document.getElementById('app');
  class ReactClassComp extends React.Component {
    render(){
      return (
      <div>
      <p>用戶名:<input type="text" value={ this.props.name }/></p>
      <p>性別:<input type="text" value={ this.props.gender }/></p>
      </div>
      )
    }
  }

  ReactClassComp.defaultProps={
    name:'劉備',
    gender:'男'
  }
  const reactp=(
    <span>
      {<ReactClassComp />}  
    </span>
  )
  ReactDOM.render(reactp,reactDiv)
</script>

在這里插入圖片描述

注意: 在很多場合中,組件的內容需要根據數據的刷新而刷新,這個時候就需要用到React提供的State

三、State狀態(tài)

  • React將組件看作是狀態(tài)機,通過內部定義的狀態(tài)與生命周期實現與用戶的交互,維持組建的不同狀態(tài),然后通過渲染UI保證用戶界面和數據一致性。
  • 創(chuàng)建方式:利用ES6的class繼承方法super,可以將props傳遞到React.Component的構造函數中。

1.React生命周期 掛載(mount):

當組件實例被創(chuàng)建并插入DOM中時

(1)constructor(props) -->在組件掛載之前,會調用它的構造函數。如果不需要初始化state或不進行方法綁定,則不需要創(chuàng)建構造函數。

構造函數僅用于以下兩種情況:

  • 通過給this.state賦值對象來初始化內部state
  • 為事件處理函數綁定實例

注意: 在constructor()函數中不要調用setState()方法。如果需要使用內部state,可直接在構造函數中為this.state賦值初始化state.

constructor(props){
	super(props);
		this.state = {
			date:new Date()
		}
		this.handleShow = this.handleShow.bind(this)
	
}

(2) render() -->必須要實現的

會檢查this.props和this.state的變化并返回以下類型之一:

  • React元素:通常通過JSX創(chuàng)建
  • 數組或fragments:返回多個
  • Portals:可以渲染節(jié)點到不同的DOM子樹中
  • 字符串或數值類型:被渲染為文本節(jié)點
  • 布爾類型或null:什么都不渲染

純函數:在不修改組件state的情況下,每次調用都返回相同的結果,并且它不會直接與瀏覽器交互。
如果需與瀏覽器進行交互,在ComponmentDidMount()或其他生命周期中進行定義

(3) ComponmentDidMount() -->在組件掛載后立即調用。

  • 依賴DOM節(jié)點的初始化
  • 實例化網絡請求獲取數據
  • 添加訂閱,需要在componentWillUnmount()中取消訂閱

注意: 可以在ComponmentDidMount()中直接調用setState()。它將觸發(fā)額外渲染,但此渲染會發(fā)生在瀏覽器更新屏幕之前。保證了即使在render()兩次調用的情況下,用戶不會看到中間狀態(tài)。

更新:

compomentDidUpdate(prevProps,prevProps,snapshot):更新后立即調用,首次渲染不會執(zhí)行此方法,當組件更新后,可以在此處對DOM進行操作。

compomentDidUpdate(prevProps){
	if(this.props.userID !== prevProps.userID){
		this.fetchData(this.props.userID)
	}
}

注意: 若在compomentDidUpdate() 調用setState(),需要包裹在一個條件語句中,否則會導致死循環(huán)。還會導致額外的重新渲染,雖然用戶不可見,但會影響組件性能。

卸載:

componentWillUnmount() -->在組件卸載及銷毀之前直接調用。
注意: componentWillUnmount()中不應調用setState()方法,因為組件將永遠不會重新渲染。組件實例卸載后,將永遠不會再掛載它。

2.生命周期實例-->時鐘:

<div id="app"></div>
<script type="text/babel">
  var reactDiv = document.getElementById('app')
  //定義類組件 MyStateComp 
  class MyStateComp extends React.Component {
    //構造函數
    constructor(props) {
      super(props); 
      //通過this.state初始化state內部
      this.state = {
        date:new Date(),
        show:false,
        text:'顯示'
      }
      //為事件處理函數綁定實例
      this.handleShow = this.handleShow.bind(this)
    }
    //添加訂閱
    componentDidMount() {
      this.timerID = setInterval(()=>this.tick(),1000)
    }
    //時間函數
    tick() {
      this.setState({  //setState更新組件的state
        date:new Date()
      })
    }
    //實例顯示、隱藏
    handleShow() {
      this.setState(state=>({
        show: !state.show,
        text: !state.show?'隱藏':'顯示'
      }))
    }
    //組件卸載:清空定時器
    componentWillUnmont() {
      clearInterval(this.timerID)
    }
    
    render() {
      let isShow=this.state.show;
      let element;
      if(isShow){
        element = <h2 >{this.state.date.toLocaleTimeString()}</h2> 
      }else{
        element = null
      }
      return (
        <div>
          <button onClick={this.handleShow}>{this.state.text}時間</button>
          {element}
        </div>
      )
    }
  }
  const reactSpan = (
    <span>
      {<MyStateComp/> }  
    </span>
  )
  ReactDOM.render(reactSpan,reactDiv)
</script>

在這里插入圖片描述

到此這篇關于React State狀態(tài)與生命周期的文章就介紹到這了,更多相關React State生命周期內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • react四種組件中DOM樣式設置方式詳解

    react四種組件中DOM樣式設置方式詳解

    這篇文章主要介紹了react之四種組件中DOM樣式設置方式,通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-10-10
  • React大文件分片上傳原理及方案

    React大文件分片上傳原理及方案

    前端進行大文件分片上傳的方案幾乎都是利用Blob.prototype.slice方法對文件進行分片,用數組將每一個分片存起來,最后將分片發(fā)給后端,本文給大家介紹React大文件分片上傳方案,感興趣的朋友跟隨小編一起看看吧
    2023-08-08
  • React組件中使用JSON數據文件的方法詳解

    React組件中使用JSON數據文件的方法詳解

    要在 React 組件中使用 JSON 數據,有多種方法,這篇文章主要為大家詳細介紹了五個常見的方法,文中的示例代碼講解詳細,有需要的小伙伴可以了解下
    2024-01-01
  • React-RouterV6+AntdV4實現Menu菜單路由跳轉的方法

    React-RouterV6+AntdV4實現Menu菜單路由跳轉的方法

    這篇文章主要介紹了React-RouterV6+AntdV4實現Menu菜單路由跳轉,主要有兩種跳轉方式一種是編程式跳轉另一種是NavLink鏈接式跳轉,每種方式通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • 詳解React中key的作用

    詳解React中key的作用

    這篇文章主要介紹了React中key的作用,幫助大家更好的理解和學習使用React,感興趣的朋友可以了解下
    2021-04-04
  • React-Route6實現keep-alive效果

    React-Route6實現keep-alive效果

    本文主要介紹了React-Route6實現keep-alive效果,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧<BR>
    2022-06-06
  • 說說react中引入css的方式有哪些并區(qū)別在哪

    說說react中引入css的方式有哪些并區(qū)別在哪

    本文主要介紹了說說react中引入css的方式有哪些并區(qū)別在哪,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-04-04
  • 利用React-router+Webpack快速構建react程序

    利用React-router+Webpack快速構建react程序

    目前 React、Webpack 等技術如火如荼,你是不是還在愁苦如何把這些雜亂的知識怎么學習一下,開啟一段新的前端開發(fā)之路呢?那么這篇將給大家運用示例代碼詳細的介紹使用React-router和Webpack如何快速構建一個react程序,感興趣的朋友們下面來一起看看吧。
    2016-10-10
  • 使用webpack5從0到1搭建一個react項目的實現步驟

    使用webpack5從0到1搭建一個react項目的實現步驟

    這篇文章主要介紹了使用webpack5從0到1搭建一個react項目的實現步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • React-View-UI組件庫封裝Loading加載中源碼

    React-View-UI組件庫封裝Loading加載中源碼

    這篇文章主要介紹了React-View-UI組件庫封裝Loading加載樣式,主要包括組件介紹,組件源碼及組件測試源碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06

最新評論