首頁 web前端 js教程 React中props和state屬性的用法詳解(程式碼範例)

React中props和state屬性的用法詳解(程式碼範例)

Dec 06, 2018 pm 03:45 PM
react.js 前端優化

這篇文章帶給大家的內容是關於React中props和state屬性的用法詳解(程式碼範例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。

本篇文章主要介紹了React props和state屬性的具體使用方法,具有一定的參考價值,對此有需要的朋友可以參考學習下。如有不足之處,歡迎批評指正。

props

我不知道大家還記不記得xml標籤中的屬性,就像這樣:

<class id="1">
 <student id="1">John Kindem</student>
 <student id="2">Alick Ice</student>
</class>
登入後複製

這樣一個xml檔案表達的意思是1班有兩個學生,學號為1的學生名字為John Kindem,學號為2的學生名字為Alick Ice,其中id就是屬性,你可以把它看做一個常量,它是唯讀的。
html繼承自xml,而JSX從莫種意義上又是html和js的擴展,屬性的概念自然就得到了傳承。
在React中,我們使用props這個概念​​向React元件傳遞只讀的值,就像這樣:

// 假设我们已经自定义了一个叫Hello的组件
ReactDom.render(
  <Hello firstName={&#39;John&#39;} lastName={&#39;Kindem&#39;}/>,
  document.getElementById('root')
);
登入後複製

在呼叫React元件的時候,我們可以像上面一樣傳遞一些常數,以便元件在內部呼叫。而呼叫的方法,就像下面這樣:

class Hello extends React.Component {
  constructor(props) {
    super(props);
  }
 
  render() {
    return (
      <p>
        <h1>Hello, {this.props.firstName + ' ' + this.props.lastName}</h1>
      </p>
    );//欢迎加入前端全栈开发交流圈一起学习交流:864305860
  }//面向1-3年前端人员
}//帮助突破技术瓶颈,提升思维能力
 
ReactDom.render(
  <Hello firstName={&#39;John&#39;} lastName={&#39;Kindem&#39;}/>,
  document.getElementById('root')
);
登入後複製

在元件內部取得傳遞過來的props,只需要使用this.props物件即可,但是在使用之前,記得複寫元件的建構函數,並且接受props的值以呼叫父類別建構。
當然,props也能夠設定預設值,向下面這樣:

class Hello extends React.Component {
  constructor(props) {
    super(props);
  }
 
  static defaultProps = {
    firstName: 'John',
    lastName: 'Kindem'
  };
 
  render() {
    return (
      <div>
        <h1>Hello, {this.props.firstName + ' ' + this.props.lastName}</h1>
      </div>
    );//欢迎加入前端全栈开发交流圈一起吹水聊天学习交流:864305860
  }//面向1-3年前端人员
}//帮助突破技术瓶颈,提升思维能力
 
ReactDom.render(
  <Hello/>,
  document.getElementById('root')
);
登入後複製

只需在ES6類別中聲明一個static的props預設值即可,運行效果和上面一樣。
props沒有多複雜,稍微練習即可習得。

state、元件生命週期

你可能會回想,如果我想在React元件中加入動態效果怎麼辦?這個問題需要使用React元件的state來解決,state即狀態的意思,在React中,所有會變化的控制變數都應該放入state,每當state中的內容變化時,頁面的對應元件將會被重新渲染,另外,state完全是元件內部的東西,外部無法向內部傳遞state,無法直接改變state的值。
先來舉一個例子:

import React from 'react';
import ReactDom from 'react-dom';
 
class Time extends React.Component {
  constructor(props) {
    super(props);
 
    // 初始化state
    this.state = {
      hour: 0,
      minute: 0,
      second: 0
    }
  }
  componentDidMount() {
    this.interval = setInterval(() => this.tick(), 1000);
  }
 
  componentWillUnmount() {
    clearInterval(this.interval);
  }
 
  tick() {
    // 计算新时间
    let newSecond, newMinute, newHour;
    let carryMinute = 0, carryHour = 0;
    newSecond = this.state.second + 1;
    if (newSecond > 59) {
      carryMinute = 1;
      newSecond -= 60;
    }
    newMinute = this.state.minute + carryMinute;
    if (newMinute > 59) {
      carryHour = 1;
      newMinute -= 60;
    }
    newHour = this.state.hour + carryHour;
    if (newHour > 59) newHour -= 60;
 
    // 设置新状态
    this.setState({
      hour: newHour,
      minute: newMinute,
      second: newSecond
    });
  }
 
  render() {
    return (
      <div>
        <h1>current time: {this.state.hour + ':' + this.state.minute + ':' + this.state.second}</h1>
      </div>
    );
  }
}
ReactDom.render(
  <Time/>,
  document.getElementById('root')
);
登入後複製

這樣就完成了一個計數器,數值一秒鐘變化一次,來講解一下程式碼:首先,state的初始化是在建構子中,像這樣:

constructor(props) {
  super(props);
 
  // 在这初始化state
  this.state = {
    ...
  }
}
登入後複製

而改變state是使用React元件基底類別中的一個自帶函數:

this.setState({
  ...
});
登入後複製

使用這個函數之前一定要注意this的作用域,箭頭函數中的this指向外部this,而普通函數中的this指向函數本身。
另外,這裡使用到了兩個React元件的生命週期回呼:`

componentDidMount() {
  // React组件被加载到dom中的时候被调用
  ...
}
componentWillUnmount() {
  // React组件从dom中卸载的时候被调用
  ...
}
登入後複製

所以這樣一下上面的計時器程式碼應該就不是什麼難事了,在React元件被載入到dom的時候設定計時器,每秒鐘更新一次state,state更新的同時頁面中的元件將會被重新渲染,而當元件被卸載的時候,則需要清除計時器,就那麼簡單。
不過React對於state的更新頻率,有一個最大的限度,超過這個限度則會導致頁面渲染的效能下降,大家需要注意不要在高頻函數中使用setState。


以上是React中props和state屬性的用法詳解(程式碼範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

React父元件怎麼呼叫子元件的方法 React父元件怎麼呼叫子元件的方法 Dec 27, 2022 pm 07:01 PM

呼叫方法:1、類別元件中的呼叫可以利用React.createRef()、ref的函數式宣告或props自訂onRef屬性來實作;2、函式元件、Hook元件中的呼叫可以利用useImperativeHandle或forwardRef拋出子組件ref來實作。

如何透過前端優化提升Python網站的存取速度? 如何透過前端優化提升Python網站的存取速度? Aug 05, 2023 am 10:21 AM

如何透過前端優化提升Python網站的存取速度?隨著網路的發展,網站的存取速度成為使用者體驗的重要指標之一。而對於使用Python開發的網站來說,如何透過前端優化來提升存取速度是一個必須解決的問題。本文將介紹一些前端優化的技巧,幫助提升Python網站的存取速度。壓縮和合併靜態檔案在網頁中,靜態檔案如CSS、JavaScript和圖片等會佔用大量的頻寬和載入

提升網站速度的關鍵最佳化模式,每個前端開發者都必須掌握! 提升網站速度的關鍵最佳化模式,每個前端開發者都必須掌握! Feb 02, 2024 pm 05:36 PM

前端開發者必備:掌握這些最佳化模式,讓網站飛起來!隨著網路的快速發展,網站已成為企業宣傳和交流的重要管道之一。一個效能優良、載入迅速的網站不僅可以提升使用者體驗,還可以吸引更多的訪客。身為前端開發者,掌握一些最佳化模式是不可或缺的。本文將介紹一些常用的前端優化技術,幫助開發者更好地優化網站。壓縮檔案在網站開發中,經常使用的檔案類型包括HTML、CSS和J

深入理解React的自訂Hook 深入理解React的自訂Hook Apr 20, 2023 pm 06:22 PM

React 自訂 Hook 是將元件邏輯封裝在可重複使用函數中的方式,它們提供了一種在不編寫類別的情況下重複使用狀態邏輯的方式。本文將詳細介紹如何自訂封裝 hook。

怎麼調試R​​eact源碼?多種工具下的除錯方法介紹 怎麼調試R​​eact源碼?多種工具下的除錯方法介紹 Mar 31, 2023 pm 06:54 PM

怎麼調試R​​eact源碼?以下這篇文章帶大家聊聊多種工具下的調試React源碼的方法,介紹一下在貢獻者、create-react-app、vite專案中如何debugger React的真實源碼,希望對大家有所幫助!

React行動裝置適配指南:如何最佳化前端應用在不同螢幕上的顯示效果 React行動裝置適配指南:如何最佳化前端應用在不同螢幕上的顯示效果 Sep 29, 2023 pm 04:10 PM

React行動裝置適配指南:如何優化前端應用程式在不同螢幕上的顯示效果近年來,隨著行動網路的快速發展,越來越多的使用者習慣使用手機來瀏覽網站和使用各種應用程式。然而,不同手機螢幕的尺寸和解析度千差萬別,這給前端開發帶來了一定的挑戰。為了讓網站和應用程式在不同螢幕上都有良好的顯示效果,我們需要進行行動端適配,並對前端程式碼進行相應的最佳化。使用響應式佈局響應式佈局是一種根據螢幕

react怎麼設定div高度 react怎麼設定div高度 Jan 06, 2023 am 10:19 AM

react設定div高度的方法:1、透過css方式實現div高度;2、在state中宣告一個物件C,並在該物件中存放更換按鈕的樣式,然後取得A並重新設定C中的「marginTop」即可。

確保可維護的WordPress元框:完成前端部分 確保可維護的WordPress元框:完成前端部分 Aug 27, 2023 pm 11:33 PM

在本系列文章中,我們將回顧一些可用於構建更易於維護的WordPress插件的技巧和策略,並且我們將通過利用選項卡式元框的插件的上下文來實現這一切.在上一篇文章中,我們專門為我們的選項卡實現了功能,並且還實現了第一個textarea,它將用於捕獲一些用戶輸入。對於那些一直關注的人來說,您知道我們只做到了:使選項卡發揮作用引入用戶可以與之交互的單個UI元素我們尚未完成清理、驗證和保存數據的實際過程,也沒有費心介紹其餘選項卡的內容。在接下來的兩篇文章中,我們將正是這樣做的。具體來說,在本文中,我們將繼

See all articles