# Week 3

This session is about understanding and utilizing Hooks in React components, especially `useEffect`.

## Contents

* [Preparation](/course-content/frontend/react/week3/preparation.md)
* [Session Plan](/course-content/frontend/react/week3/session-plan.md) (for mentors)
* [Assignment](/course-content/frontend/react/week3/assignment.md)

## Session Learning Goals

By the end of this session, you will:

### Forms / Event Handling

* [ ] Know how to build interactive forms as React components
* [ ] Be familiar with React's way to attach (DOM) events to elements
* [ ] Be able to submit a form and process the form data in JavaScript

### Hooks

* [ ] Understand how and why React uses Hooks
* [ ] Have tried the `useEffect` hook in different contexts
* [ ] Know how to use `useEffect` to synchronize with other systems (like the DOM or browser window)

### Loading Data

* [ ] Be able to load data from an API utilizing `fetch`, and the `useEffect` and `useState` hooks
* [ ] Understand at what time(s) your data will be loaded from the API


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://program.hackyourfuture.dk/course-content/frontend/react/week3.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
