Heim Web-Frontend js-Tutorial Was sind die Unterschiede zwischen State und Props in React?

Was sind die Unterschiede zwischen State und Props in React?

Nov 17, 2020 pm 04:49 PM
react state props

Unterschied: Requisiten werden an die Komponente übergeben (ähnlich den formalen Parametern einer Funktion), während der Status innerhalb der Komponente von der Komponente selbst verwaltet wird (ähnlich einer innerhalb einer Funktion deklarierten Variablen). Der Zustand ist die eigene Datenverwaltung und Kontrolle der Komponente, die variabel ist; Requisiten sind die von außen übergebenen Datenparameter, die unveränderlich sind.

Was sind die Unterschiede zwischen State und Props in React?

Die Betriebsumgebung dieses Tutorials: Windows 7-System, React18-Version, Dell G3-Computer.

Verwandte Empfehlungen: „React Video Tutorial

props

Die Kernidee von React ist die Idee der Komponentisierung, und die Seite wird in einige unabhängige und wiederverwendbare Komponenten unterteilt.

Konzeptionell ist eine Komponente eine Funktion, die einen Parameter als Eingabewert akzeptieren kann. Dieser Parameter ist props, sodass props als an die Komponente übergeben angesehen werden kann die Außendaten. Da es sich bei React um einen unidirektionalen Datenfluss handelt, handelt es sich bei props im Wesentlichen um die Daten, die von der übergeordneten Komponente an die untergeordnete Komponente übergeben werden. props,所以可以把props理解为从外部传入组件内部的数据。由于React是单向数据流,所以props基本上也就是从服父级组件向子组件传递的数据。

用法

假设我们现在需要实现一个列表,根据React组件化思想,我们可以把列表中的行当做一个组件,也就是有这样两个组件:<ItemList/><Item/>

先看看<ItemList/>

import Item from "./item";
export default class ItemList extends React.Component{
  const itemList = data.map(item => <Item item=item />);
  render(){
    return (
      {itemList}
    )
  }
}
Nach dem Login kopieren

列表的数据我们就暂时先假设是放在一个data变量中,然后通过map函数返回一个每一项都是<Item item=&#39;数据&#39;/>的数组,也就是说这里其实包含了data.length<Item/>组件,数据通过在组件上自定义一个参数传递。当然,这里想传递几个自定义参数都可以。

<Item />中是这样的:

export default class Item extends React.Component{
  render(){
    return (
      <li>{this.props.item}</li>
    )
  }
}
Nach dem Login kopieren

render函数中可以看出,组件内部是使用this.props来获取传递到该组件的所有数据,它是一个对象,包含了所有你对这个组件的配置,现在只包含了一个item属性,所以通过this.props.item来获取即可。

只读性

props经常被用作渲染组件和初始化状态,当一个组件被实例化之后,它的props是只读的,不可改变的。如果props在渲染过程中可以被改变,会导致这个组件显示的形态变得不可预测。只有通过父组件重新渲染的方式才可以把新的props传入组件中。

默认参数

在组件中,我们最好为props中的参数设置一个defaultProps,并且制定它的类型。比如,这样:

Item.defaultProps = {
  item: &#39;Hello Props&#39;,
};

Item.propTypes = {
  item: PropTypes.string,
};
Nach dem Login kopieren

关于propTypes,可以声明为以下几种类型:

optionalArray: PropTypes.array,
optionalBool: PropTypes.bool,
optionalFunc: PropTypes.func,
optionalNumber: PropTypes.number,
optionalObject: PropTypes.object,
optionalString: PropTypes.string,
optionalSymbol: PropTypes.symbol,
Nach dem Login kopieren

总结

props是一个从外部传进组件的参数,主要作为就是从父组件向子组件传递数据,它具有可读性和不变性,只能通过外部组件主动传入新的props来重新渲染子组件,否则子组件的props以及展现形式不会改变。

state

state是什么呢?

State is similar to props, but it is private and fully controlled by the component.
Nach dem Login kopieren

一个组件的显示形态可以由数据状态和外部参数所决定,外部参数也就是props,而数据状态就是state

用法

export default class ItemList extends React.Component{
  constructor(){
    super();
    this.state = {
      itemList:&#39;一些数据&#39;,
    }
  }
  render(){
    return (
      {this.state.itemList}
    )
  }
}
Nach dem Login kopieren

首先,在组件初始化的时候,通过this.state给组件设定一个初始的state,在第一次render的时候就会用这个数据来渲染组件。

setState

state不同于props的一点是,state是可以被改变的。不过,不可以直接通过this.state=的方式来修改,而需要通过this.setState()方法来修改state

比如,我们经常会通过异步操作来获取数据,我们需要在didMount阶段来执行异步操作:

componentDidMount(){
  fetch(&#39;url&#39;)
    .then(response => response.json())
    .then((data) => {
      this.setState({itemList:item});  
    }
}
Nach dem Login kopieren

当数据获取完成后,通过this.setState来修改数据状态。

当我们调用this.setState方法时,React会更新组件的数据状态state,并且重新调用render方法,也就是会对组件进行重新渲染。

注意:通过this.state=来初始化state,使用this.setState来修改stateconstructor是唯一能够初始化的地方。

setState

🎜Verwendung🎜🎜🎜Angenommen, wir müssen jetzt eine Liste implementieren. Gemäß der React-Komponentisierungsidee können wir die Zeilen in der Liste als Komponente behandeln, das heißt, es gibt zwei Komponenten wie diese: < ItemList/>< /code> und <Item/>. 🎜🎜Schauen Sie sich zunächst die Daten von <ItemList/> an. 🎜
export default class ItemList extends React.Component{
  constructor(){
    super();
    this.state = {
      name:&#39;axuebin&#39;,
      age:25,
    }
  }
  componentDidMount(){
    this.setState({age:18})  
  }
}
Nach dem Login kopieren
Nach dem Login kopieren
🎜Wir gehen vorerst davon aus, dass sie in einer data-Variable platziert sind, und übergeben sie dann mapDie Funktion gibt ein Array zurück, in dem jedes Element <Item item='data'/> ist, was bedeutet, dass es tatsächlich data.length< enthält /code> Eine <Item/>-Komponente. Daten werden durch Anpassen eines Parameters an die Komponente übergeben. Natürlich können Sie hier beliebig viele benutzerdefinierte Parameter übergeben. 🎜🎜In <Item /> sieht es so aus: 🎜
this.setState({
  name:&#39;xb&#39;
},()=>console.log(&#39;setState finished&#39;))
Nach dem Login kopieren
Nach dem Login kopieren
🎜Wie Sie in der Funktion render sehen können, verwendet die Komponente this.props< /code>, um alle an die Komponente übergebenen Daten abzurufen. Es handelt sich um ein Objekt, das alle Ihre Konfigurationen für diese Komponente enthält. Jetzt enthält es nur ein <code>item-Attribut, also übergeben Sie einfach this props.item. 🎜🎜🎜Schreibgeschützt🎜🎜🎜props wird häufig zum Rendern von Komponenten und dem Initialisierungsstatus verwendet. Wenn eine Komponente instanziiert wird, sind ihre props nicht änderbar. Wenn props während des Rendervorgangs geändert werden kann, wird die Anzeigeform dieser Komponente unvorhersehbar. Neue props können nur durch erneutes Rendern der übergeordneten Komponente an die Komponente übergeben werden. 🎜🎜🎜Standardparameter🎜🎜🎜In der Komponente legen wir besser einen defaultProps für die Parameter in props fest und geben dessen Typ an. Zum Beispiel dies: 🎜rrreee🎜 In Bezug auf propTypes können die folgenden Typen deklariert werden: 🎜rrreee🎜🎜Summary🎜🎜🎜props ist ein Parameter, der an die Komponente übergeben wird Von außen besteht seine Hauptfunktion darin, Daten von der übergeordneten Komponente an die untergeordnete Komponente zu übertragen. Sie ist lesbar und unveränderlich. Die untergeordnete Komponente kann nur durch aktive Übergabe neuer props neu gerendert werden Andernfalls ändern sich die props der untergeordneten Komponente nicht. 🎜🎜🎜🎜Zustand🎜🎜🎜🎜Was ist Zustand? 🎜rrreee🎜Die Anzeigeform einer Komponente kann durch den Datenstatus und externe Parameter bestimmt werden. Die externen Parameter sind props und der Datenstatus ist state🎜🎜🎜Verwendung 🎜🎜rrreee 🎜Zuerst, wenn die Komponente initialisiert wird, legen Sie über this.state einen anfänglichen state für die Komponente fest, und beim ersten Mal render</ Code> Diese Daten werden zum Rendern der Komponente verwendet. 🎜🎜🎜setState🎜🎜🎜<code>state unterscheidet sich von props darin, dass state geändert werden kann. Es kann jedoch nicht direkt über this.state= geändert werden. Stattdessen muss state über die Methode this.setState() geändert werden. 🎜🎜Zum Beispiel erhalten wir Daten häufig durch asynchrone Vorgänge. Wir müssen asynchrone Vorgänge in der Phase didMount ausführen: 🎜rrreee🎜Nachdem die Datenerfassung abgeschlossen ist, übergeben Sie this.setState</. Code >, um den Datenstatus zu ändern. 🎜🎜Wenn wir die Methode <code>this.setState aufrufen, aktualisiert React den Datenstatus state der Komponente und ruft die Methode render erneut auf, d. h. Dadurch wird die Komponente neu gerendert. 🎜🎜🎜Hinweis: Verwenden Sie this.state=, um state zu initialisieren, verwenden Sie this.setState, um state zu ändern, constructor ist der einzige Ort, der initialisiert werden kann. 🎜🎜🎜setState akzeptiert ein Objekt oder eine Funktion als ersten Parameter. Sie müssen nur den Teil übergeben, der aktualisiert werden muss, nicht das gesamte Objekt, wie zum Beispiel: 🎜
export default class ItemList extends React.Component{
  constructor(){
    super();
    this.state = {
      name:&#39;axuebin&#39;,
      age:25,
    }
  }
  componentDidMount(){
    this.setState({age:18})  
  }
}
Nach dem Login kopieren
Nach dem Login kopieren

在执行完setState之后的state应该是{name:&#39;axuebin&#39;,age:18}

setState还可以接受第二个参数,它是一个函数,会在setState调用完成并且组件开始重新渲染时被调用,可以用来监听渲染是否完成:

this.setState({
  name:&#39;xb&#39;
},()=>console.log(&#39;setState finished&#39;))
Nach dem Login kopieren
Nach dem Login kopieren

总结

state的主要作用是用于组件保存、控制以及修改自己的状态,它只能在constructor中初始化,它算是组件的私有属性,不可通过外部访问和修改,只能通过组件内部的this.setState来修改,修改state属性会导致组件的重新渲染。

区别

  • props是传递给组件的(类似于函数的形参),而state是在组件内部被组件自己管理的(类似于在一个函数内声明的变量)

  • state是组件自己管理数据,控制自己的状态,可变;props是外部传入的数据参数,不可变;

  • 没有state的叫做无状态组件,有state的叫做有状态组件;

  • 多用props,少用state。也就是多写无状态组件。

更多编程相关知识,请访问:编程教学!!

Das obige ist der detaillierte Inhalt vonWas sind die Unterschiede zwischen State und Props in React?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So erstellen Sie eine Echtzeit-Chat-App mit React und WebSocket So erstellen Sie eine Echtzeit-Chat-App mit React und WebSocket Sep 26, 2023 pm 07:46 PM

So erstellen Sie eine Echtzeit-Chat-Anwendung mit React und WebSocket Einführung: Mit der rasanten Entwicklung des Internets hat die Echtzeitkommunikation immer mehr Aufmerksamkeit auf sich gezogen. Live-Chat-Apps sind aus dem modernen Sozial- und Arbeitsleben nicht mehr wegzudenken. In diesem Artikel wird erläutert, wie Sie mit React und WebSocket eine einfache Echtzeit-Chat-Anwendung erstellen, und es werden spezifische Codebeispiele bereitgestellt. 1. Technische Vorbereitung Bevor wir mit der Erstellung einer Echtzeit-Chat-Anwendung beginnen, müssen wir die folgenden Technologien und Tools vorbereiten: React: eine zum Erstellen

Leitfaden zur React-Front-End- und Back-End-Trennung: So erreichen Sie die Entkopplung und unabhängige Bereitstellung von Front-End und Back-End Leitfaden zur React-Front-End- und Back-End-Trennung: So erreichen Sie die Entkopplung und unabhängige Bereitstellung von Front-End und Back-End Sep 28, 2023 am 10:48 AM

React-Leitfaden zur Front-End- und Back-End-Trennung: So erreichen Sie die Front-End- und Back-End-Entkopplung und die unabhängige Bereitstellung. Es sind spezifische Codebeispiele erforderlich. In der heutigen Webentwicklungsumgebung ist die Front-End- und Back-End-Trennung zu einem Trend geworden. Durch die Trennung von Front-End- und Back-End-Code kann die Entwicklungsarbeit flexibler und effizienter gestaltet und die Zusammenarbeit im Team erleichtert werden. In diesem Artikel wird erläutert, wie Sie mithilfe von React eine Front-End- und Back-End-Trennung erreichen und so die Ziele der Entkopplung und unabhängigen Bereitstellung erreichen. Zuerst müssen wir verstehen, was Front-End- und Back-End-Trennung ist. Im traditionellen Webentwicklungsmodell sind Front-End und Back-End gekoppelt

So erstellen Sie einfache und benutzerfreundliche Webanwendungen mit React und Flask So erstellen Sie einfache und benutzerfreundliche Webanwendungen mit React und Flask Sep 27, 2023 am 11:09 AM

So erstellen Sie mit React und Flask einfache und benutzerfreundliche Webanwendungen. Einführung: Mit der Entwicklung des Internets werden die Anforderungen an Webanwendungen immer vielfältiger und komplexer. Um den Anforderungen der Benutzer an Benutzerfreundlichkeit und Leistung gerecht zu werden, wird es immer wichtiger, moderne Technologie-Stacks zum Aufbau von Netzwerkanwendungen zu verwenden. React und Flask sind zwei sehr beliebte Frameworks für die Front-End- und Back-End-Entwicklung, und sie arbeiten gut zusammen, um einfache und benutzerfreundliche Webanwendungen zu erstellen. In diesem Artikel erfahren Sie, wie Sie React und Flask nutzen

So erstellen Sie eine zuverlässige Messaging-App mit React und RabbitMQ So erstellen Sie eine zuverlässige Messaging-App mit React und RabbitMQ Sep 28, 2023 pm 08:24 PM

So erstellen Sie eine zuverlässige Messaging-Anwendung mit React und RabbitMQ Einführung: Moderne Anwendungen müssen zuverlässiges Messaging unterstützen, um Funktionen wie Echtzeitaktualisierungen und Datensynchronisierung zu erreichen. React ist eine beliebte JavaScript-Bibliothek zum Erstellen von Benutzeroberflächen, während RabbitMQ eine zuverlässige Messaging-Middleware ist. In diesem Artikel wird erläutert, wie Sie React und RabbitMQ kombinieren, um eine zuverlässige Messaging-Anwendung zu erstellen, und es werden spezifische Codebeispiele bereitgestellt. RabbitMQ-Übersicht:

Leitfaden für reaktionsfähiges Design: So erzielen Sie adaptive Front-End-Layouteffekte Leitfaden für reaktionsfähiges Design: So erzielen Sie adaptive Front-End-Layouteffekte Sep 26, 2023 am 11:34 AM

React Responsive Design Guide: So erzielen Sie adaptive Front-End-Layouteffekte Mit der Beliebtheit mobiler Geräte und der steigenden Nachfrage der Benutzer nach Multi-Screen-Erlebnissen ist Responsive Design zu einem der wichtigsten Aspekte in der modernen Front-End-Entwicklung geworden. React, eines der derzeit beliebtesten Frontend-Frameworks, bietet eine Fülle von Tools und Komponenten, die Entwicklern dabei helfen, adaptive Layouteffekte zu erzielen. In diesem Artikel werden einige Richtlinien und Tipps zur Implementierung von responsivem Design mit React vorgestellt und spezifische Codebeispiele als Referenz bereitgestellt. Fle mit React

Anleitung zum Debuggen von React-Code: So finden und beheben Sie Front-End-Fehler schnell Anleitung zum Debuggen von React-Code: So finden und beheben Sie Front-End-Fehler schnell Sep 26, 2023 pm 02:25 PM

React-Code-Debugging-Leitfaden: So finden und beheben Sie Front-End-Fehler schnell. Einführung: Bei der Entwicklung von React-Anwendungen stoßen Sie häufig auf eine Vielzahl von Fehlern, die zum Absturz der Anwendung oder zu fehlerhaftem Verhalten führen können. Daher ist die Beherrschung von Debugging-Fähigkeiten eine wesentliche Fähigkeit für jeden React-Entwickler. In diesem Artikel werden einige praktische Techniken zum Auffinden und Beheben von Front-End-Fehlern vorgestellt und spezifische Codebeispiele bereitgestellt, um Lesern dabei zu helfen, Fehler in React-Anwendungen schnell zu finden und zu beheben. 1. Auswahl der Debugging-Tools: In Re

React Router-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung React Router-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung Sep 29, 2023 pm 05:45 PM

ReactRouter-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung Mit der Popularität von Single-Page-Anwendungen ist das Front-End-Routing zu einem wichtigen Bestandteil geworden, der nicht ignoriert werden kann. Als beliebteste Routing-Bibliothek im React-Ökosystem bietet ReactRouter umfangreiche Funktionen und benutzerfreundliche APIs, wodurch die Implementierung des Front-End-Routings sehr einfach und flexibel ist. In diesem Artikel wird die Verwendung von ReactRouter vorgestellt und einige spezifische Codebeispiele bereitgestellt. Um ReactRouter zuerst zu installieren, benötigen wir

So erstellen Sie eine schnelle Datenanalyseanwendung mit React und Google BigQuery So erstellen Sie eine schnelle Datenanalyseanwendung mit React und Google BigQuery Sep 26, 2023 pm 06:12 PM

So verwenden Sie React und Google BigQuery zum Erstellen schneller Datenanalyseanwendungen. Einführung: Im heutigen Zeitalter der Informationsexplosion ist die Datenanalyse zu einem unverzichtbaren Bindeglied in verschiedenen Branchen geworden. Unter anderem ist die Entwicklung schneller und effizienter Datenanalyseanwendungen für viele Unternehmen und Einzelpersonen zum Ziel geworden. In diesem Artikel wird erläutert, wie Sie mit React und Google BigQuery eine schnelle Datenanalyseanwendung erstellen, und es werden detaillierte Codebeispiele bereitgestellt. 1. Übersicht React ist ein Werkzeug zum Erstellen

See all articles