Inhaltsverzeichnis
Grundlegende Verwendung von useEffecf
清除副作用(Effect)" >清除副作用(Effect)
使用多个useEffect" >使用多个useEffect
useEffect Die Callback-Funktion A selbst kann einen Rückgabewert haben, und dieser Rückgabewert ist ein weiterer Rückruffunktion B:" >useEffect Die Callback-Funktion A selbst kann einen Rückgabewert haben, und dieser Rückgabewert ist ein weiterer Rückruffunktion B:
Heim Web-Frontend js-Tutorial Eine kurze Analyse der Verwendung der useEffecfa-Funktion in React Hook

Eine kurze Analyse der Verwendung der useEffecfa-Funktion in React Hook

Nov 14, 2022 pm 08:02 PM
react react hook

Dieser Artikel stellt Ihnen die useEffecfa-Funktion in React Hook vor und spricht über die Verwendungsdetails der useEffecfa-Funktion. Ich hoffe, dass er Ihnen hilfreich sein wird!

Eine kurze Analyse der Verwendung der useEffecfa-Funktion in React Hook

Detaillierte Analyse von useEffect

Grundlegende Verwendung von useEffecf

Fortsetzung von oben: Im vorherigen Artikel haben wir State Hook erklärt. Wir können ihn bereits über diesen Hook-Status in Funktionskomponenten definieren . [Verwandte Empfehlungen: Redis-Video-Tutorial, Programmiervideo]

Wir wissen, dass es in Klassenkomponenten Lebenszyklusfunktionen geben kann. Wie können diese Funktionen also ähnlich wie Lebenszyklen in Funktionskomponenten definiert werden?

Mit Effect Hook können Sie einige Funktionen ausführen, die dem Lebenszyklus in der Klasse ähneln.

Tatsächlich sind Netzwerkanforderungen, manuelle DOM-Aktualisierungen und einige Ereignisüberwachungen allesamt Nebeneffekte der React-Aktualisierung des DOM Die Vervollständigung dieser Funktionen wird als Effekt-Hook bezeichnet

Funktionskomponente plus Hook-Implementierung:

Über den useEffect-Hook können Sie React mitteilen, dass nach dem Rendern bestimmte Vorgänge ausgeführt werden müssen. useEffect erfordert, dass wir eine Rückruffunktion übergeben, die nach dem DOM-Update in React ausgeführt wird Der Vorgang ist abgeschlossen (

d. h. nachdem die Komponente gerendert wurde
), diese Funktion wird zurückgerufen;

Standardmäßig, egal ob nach dem ersten Rendern oder nach jeder Aktualisierung, Diese Rückruffunktion wird ausgeführt; im Allgemeinen schreiben wir Nebeneffektoperationen in diese Rückruffunktion (
z. B. Netzwerkanforderungen, Betriebs-DOM, Ereignisüberwachung

Es sollte also beachtet werden, dass es viele Sprichwörter gibt useEffect wird verwendet, um den Lebenszyklus zu simulieren, aber tatsächlich ist dies nicht der Fall; useEffect kann den Lebenszyklus simulieren, aber seine Hauptfunktion besteht darin, Nebenwirkungen auszuführen Effekte (Effekt)
  • Während des Schreibprozesses von Klassenkomponenten müssen wir bestimmte Nebeneffektcodes in ComponentWillUnmount löschen:
  • Zum Beispiel unser vorheriger Ereignisbus oder das manuelle Aufrufen von subscribe in Redux;默认情况下,无论是第一次渲染之后,还是每次更新之后,都会执行这个回调函数; 一般情况下我们在该回调函数中都是编写副作用的操作(例如网络请求, 操作DOM, 事件监听)

因此需要注意的是, 有许多说法说useEffect就是用来模拟生命周期的, 其实并不是; useEffect可以做到模拟生命周期, 但是他主要的作用是用来执行副作用的

import React, { PureComponent } from 'react'

export class App extends PureComponent {
  constructor() {
    super()

    this.state = {
      counter: 100
    }
  }

  // 进入页面时, 标题显示counter
  componentDidMount() {
    document.title = this.state.counter
  }

  // 数据发生变化时, 让标题一起变化
  componentDidUpdate() {
    document.title = this.state.counter
  }

  render() {
    const { counter } = this.state

    return (
      <div>
        <h2>{counter}</h2>
        <button onClick={() => this.setState({counter: counter+1})}>+1</button>
      </div>
    )
  }
}

export default App
Nach dem Login kopieren

清除副作用(Effect)

在class组件的编写过程中,某些副作用的代码,我们需要在componentWillUnmount中进行清除:

比如我们之前的事件总线或Redux中手动调用subscribe;

都需要在componentWillUnmount有对应的取消订阅;

Effect Hook通过什么方式来模拟componentWillUnmount呢?

useEffect传入的回调函数A本身可以有一个返回值,这个返回值是另外一个回调函数B:

type EffectCallback = () => (void | (() => void | undefined));

为什么要在 effect 中返回一个函数?

这是 effect 可选的清除机制。每个 effect 都可以返回一个清除函数;

如此可以将添加和移除订阅的逻辑放在一起;

它们都属于 effect 的一部分;

React 何时清除 effect?

React 会在组件更新和卸载的时候执行清除操作, 将上一次的监听取消掉, 只留下当前的监听 ;

正如之前学到的,effect 在每次渲染的时候都会执行;

import React, { memo, useEffect, useState } from &#39;react&#39;

const App = memo(() => {
  const [counter, setCounter] = useState(200)

  // useEffect传入一个回调函数, 在页面渲染完成后自动执行
  useEffect(() => {
    // 一般在该回调函数在编写副作用的代码(网络请求, 操作DOM, 事件监听)
    document.title = counter
  })

  return (
    <div>
      <h2>{counter}</h2>
      <button onClick={() => setCounter(counter+1)}>+1</button>
    </div>
  )
})

export default App
Nach dem Login kopieren

使用多个useEffect

使用Hook的其中一个目的就是解决class中生命周期经常将很多的逻辑放在一起的问题:

比如网络请求、事件监听、手动修改DOM,这些往往都会放在componentDidMount中;

一个函数组件中可以使用多个Effect Hook,我们可以将逻辑分离到不同的useEffect中:

import React, { memo, useEffect } from &#39;react&#39;

const App = memo(() => {
  useEffect(() => {
    // 监听store数据发生改变
    const unsubscribe = store.subscribe(() => {

    })

    // 返回值是一个回调函数, 该回调函数在组件重新渲染或者要卸载时执行
    return () => {
      // 取消监听操作
      unsubscribe()
    }
  })

  return (
    <div>
      <h2>App</h2>
    </div>
  )
})

export default App
Nach dem Login kopieren

Hook允许我们按照代码的用途分离它们, 而不是像生命周期函数那样, 将很多逻辑放在一起:

React将按照 effect 声明的顺序依次调用

sind beide da muss eine entsprechende Abmeldung in ComponentWillUnmount sein;

Wie simuliert Effect Hook ComponentWillUnmount?

useEffect Die Callback-Funktion A selbst kann einen Rückgabewert haben, und dieser Rückgabewert ist ein weiterer Rückruffunktion B:

type EffectCallback = () => (void | (() => void | undefiniert));

Warum eine Funktion zurückgeben möchten in der Wirkung?

Dies ist der optionale Clearing-Mechanismus der Wirkung. Jeder Effekt kann eine Löschfunktion zurückgeben;

Auf diese Weise kann die Logik des Hinzufügens und Entfernens von Abonnements zusammengestellt werden;

Sie sind alle Teil des Effekts;

Wann wird React gelöscht? ?Effekt?

🎜React führt einen Bereinigungsvorgang durch, wenn die Komponente aktualisiert und deinstalliert wird, wobei der letzte Listener gelöscht wird und nur der aktuelle Listener übrig bleibt 🎜
import React, { memo, useEffect } from &#39;react&#39;

const App = memo(() => {
  // 监听的useEffect
  useEffect(() => {
    console.log("监听的代码逻辑")

    return () => {
      console.log("取消的监听代码逻辑")
    }
  })

  // 发送网络请求的useEffect
  useEffect(() => {
    console.log("网络请求的代码逻辑")
  })

  // 操作DOM的useEffect
  useEffect(() => {
    console.log("操作DOM的代码逻辑")
  })

  return (
    <div>
      App
    </div>
  )
})

export default App
Nach dem Login kopieren
🎜🎜🎜🎜Mehrfachen useEffect verwenden🎜🎜🎜🎜Einer der Zwecke der Verwendung von Hook besteht darin, das Problem zu lösen, dass im Lebenszyklus einer Klasse oft viel Logik zusammengefügt wird🎜: 🎜 🎜🎜Wie Netzwerkanfragen, Ereignisüberwachung und manuelle Änderung des DOM werden diese häufig in „componentDidMount“ platziert
import React, { memo, useEffect, useState } from &#39;react&#39;

const App = memo(() => {
  const [counter, setCounter] = useState(100)
  
  // 发送网络请求的useEffect, 只有在counter发生改变时才会重新执行
  useEffect(() => {
    console.log("网络请求的代码逻辑")
  }, [counter])

  return (
    <div>
      <h2 onClick={() => setCounter(counter+1)}>{counter}</h2>
    </div>
  )
})

export default App
Nach dem Login kopieren
Nach dem Login kopieren
🎜🎜Hook ermöglicht es uns, den Code nach seinem Zweck zu trennen, anstatt viel Logik wie Lebenszyklusfunktionen zusammenzufügen🎜:🎜🎜🎜React ruft die Komponente in der Reihenfolge entsprechend auf Reihenfolge der Effektdeklaration Jeder Effekt;🎜🎜🎜🎜🎜🎜🎜 useEffect-Leistungsoptimierung🎜🎜🎜🎜Standardmäßig wird die Rückruffunktion von useEffect bei jedem Rendern erneut ausgeführt. Dies führt jedoch zu zwei Problemen🎜:🎜🎜🎜Einige Wir möchten den Code nur einmal ausführen (🎜Zum Beispiel kann eine Netzwerkanforderung einmal beim ersten Rendern der Komponente ausgeführt werden, es ist nicht erforderlich, sie mehrmals auszuführen🎜), ähnlich wie in „componentDidMount“ und „componentWillUnmount“ in Klassenkomponenten;🎜🎜Darüber hinaus führen mehrere Ausführungen auch zu bestimmten Leistungsproblemen 🎜🎜🎜🎜Wie entscheiden wir, wann useEffect ausgeführt werden soll und wann nicht? 🎜🎜🎜🎜useEffect hat tatsächlich zwei Parameter: 🎜
  • 参数一: 执行的回调函数, 这个参数我们已经使用过了不再多说;
  • 参数二: 是一个数组类型, 表示 该useEffect在哪些state发生变化时,才重新执行;(受谁的影响才会重新执行)

案例练习:

受count影响的Effect;

但是,如果一个函数我们不希望依赖任何的内容时,也可以传入一个空的数组 []:

那么这里的两个回调函数分别对应的就是componentDidMount和componentWillUnmount生命周期函数了;

总结: useEffect可以模拟之前的class组件的生命周期(类似而不是相等), 并且它比原来的生命周期更加强大, 青出于蓝而胜于蓝

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

Das obige ist der detaillierte Inhalt vonEine kurze Analyse der Verwendung der useEffecfa-Funktion in React Hook. 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

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

<🎜>: Bubble Gum Simulator Infinity - So erhalten und verwenden Sie Royal Keys
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusionssystem, erklärt
3 Wochen 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)

Heiße Themen

Java-Tutorial
1668
14
PHP-Tutorial
1273
29
C#-Tutorial
1256
24
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:

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

PHP, Vue und React: Wie wählt man das am besten geeignete Frontend-Framework aus? PHP, Vue und React: Wie wählt man das am besten geeignete Frontend-Framework aus? Mar 15, 2024 pm 05:48 PM

PHP, Vue und React: Wie wählt man das am besten geeignete Frontend-Framework aus? Angesichts der kontinuierlichen Weiterentwicklung der Internettechnologie spielen Front-End-Frameworks eine wichtige Rolle bei der Webentwicklung. PHP, Vue und React sind drei repräsentative Frontend-Frameworks, jedes mit seinen eigenen einzigartigen Eigenschaften und Vorteilen. Bei der Auswahl des zu verwendenden Frontend-Frameworks müssen Entwickler eine fundierte Entscheidung treffen, die auf den Projektanforderungen, Teamfähigkeiten und persönlichen Vorlieben basiert. In diesem Artikel werden die Eigenschaften und Verwendungsmöglichkeiten der drei Front-End-Frameworks PHP, Vue und React verglichen.

Integration von Java-Framework und Front-End-React-Framework Integration von Java-Framework und Front-End-React-Framework Jun 01, 2024 pm 03:16 PM

Integration von Java-Framework und React-Framework: Schritte: Richten Sie das Back-End-Java-Framework ein. Projektstruktur erstellen. Konfigurieren Sie Build-Tools. Erstellen Sie React-Anwendungen. Schreiben Sie REST-API-Endpunkte. Konfigurieren Sie den Kommunikationsmechanismus. Praxisfall (SpringBoot+React): Java-Code: RESTfulAPI-Controller definieren. Reaktionscode: Rufen Sie die von der API zurückgegebenen Daten ab und zeigen Sie sie an.

So verwenden Sie React, um ein reaktionsfähiges Backend-Managementsystem zu entwickeln So verwenden Sie React, um ein reaktionsfähiges Backend-Managementsystem zu entwickeln Sep 28, 2023 pm 04:55 PM

So verwenden Sie React, um ein reaktionsfähiges Backend-Managementsystem zu entwickeln. Aufgrund der rasanten Entwicklung des Internets benötigen immer mehr Unternehmen und Organisationen ein effizientes, flexibles und einfach zu verwaltendes Backend-Managementsystem, um den täglichen Betrieb abzuwickeln. Als eine der derzeit beliebtesten JavaScript-Bibliotheken bietet React eine übersichtliche, effiziente und wartbare Möglichkeit, Benutzeroberflächen zu erstellen. In diesem Artikel wird erläutert, wie Sie mit React ein reaktionsfähiges Backend-Managementsystem entwickeln, und es werden konkrete Codebeispiele aufgeführt. Erstellen Sie zunächst ein React-Projekt

Vue.js vs. React: projektspezifische Überlegungen Vue.js vs. React: projektspezifische Überlegungen Apr 09, 2025 am 12:01 AM

Vue.js eignet sich für kleine und mittelgroße Projekte und schnelle Iterationen, während React für große und komplexe Anwendungen geeignet ist. 1) Vue.js ist einfach zu bedienen und für Situationen geeignet, in denen das Team nicht ausreicht oder die Projektskala klein ist. 2) React hat ein reichhaltigeres Ökosystem und eignet sich für Projekte mit hoher Leistung und komplexen funktionalen Bedürfnissen.

Reacts Rolle bei HTML: Verbesserung der Benutzererfahrung Reacts Rolle bei HTML: Verbesserung der Benutzererfahrung Apr 09, 2025 am 12:11 AM

React kombiniert JSX und HTML, um die Benutzererfahrung zu verbessern. 1) JSX bettet HTML ein, um die Entwicklung intuitiver zu gestalten. 2) Der virtuelle DOM -Mechanismus optimiert die Leistung und reduziert den DOM -Betrieb. 3) Komponentenbasierte Verwaltungs-Benutzeroberfläche zur Verbesserung der Wartbarkeit. 4) Staatsmanagement und Ereignisverarbeitung verbessern die Interaktivität.

Welche Verschlüsse hat React? Welche Verschlüsse hat React? Oct 27, 2023 pm 03:11 PM

React verfügt über Abschlüsse wie Event-Handling-Funktionen, useEffect und useCallback, Komponenten höherer Ordnung usw. Ausführliche Einführung: 1. Abschluss der Ereignisbehandlungsfunktion: Wenn wir in React eine Ereignisbehandlungsfunktion in einer Komponente definieren, bildet die Funktion einen Abschluss und kann auf den Status und die Eigenschaften innerhalb des Komponentenbereichs zugreifen. Auf diese Weise können der Status und die Eigenschaften der Komponente in der Ereignisverarbeitungsfunktion verwendet werden, um interaktive Logik zu implementieren. 2. Abschlüsse in useEffect und useCallback usw.

See all articles