Почему срабатывает useEffect?
Писал код и заметил что UseEffect срабатывает не там где нужно, как мне кажется, установленая зависимость вроде бы не меняется а хук всёравно срабатывает, нужно объяснение
useTodo.ts
import React, { FormEvent, useEffect } from "react"
export interface ITodo {
id: number
title: string
description: string
}
export interface IUseTodoReturn {
functions: {
create: (title: string, description: string) => void
delete: (id: number) => void
}
get: ITodo[]
set: (array: ITodo[]) => void
}
export const useTodo = (): IUseTodoReturn => {
const [todo, setTodo] = React.useState<ITodo[]>([])
useEffect(() => {
console.log('test')
}, [ todo ])
const set = (array: ITodo[]) => {
setTodo(array)
}
const createTodo = (title: string, description: string): void => {
setTodo([...todo, { id: Date.now(), title, description }])
}
const deleteTodo = (id: number) => {
const filteredArray = todo.filter(todo => todo.id !== id)
setTodo(filteredArray)
}
return {
functions: { create: createTodo, delete: deleteTodo },
get: todo,
set
}
}
'use client'
import React, { FormEvent, forwardRef, useEffect, useRef, useState } from 'react'
import { Box, Button, Stack, TextField, Typography } from '@mui/material'
import styles from './mainPage.module.scss'
import { useTodo } from '../../hooks/useTodo'
const MainPage = () => {
const { functions, get, set } = useTodo()
const titleRef = useRef<HTMLInputElement>()
const descRef = useRef<HTMLInputElement>()
const sendTodo = (e: FormEvent) => {
e.preventDefault()
if (!titleRef.current?.value || !descRef.current?.value) return
functions.create(titleRef.current.value, descRef.current.value)
titleRef.current.value = ''
descRef.current.value = ''
}
return (
<div className={styles.root}>
<Stack className={styles.form} spacing={1} component='form' onSubmit={(e) => sendTodo(e)}>
<TextField inputRef={titleRef} sx={{ width: '30%' }} id="outlined-basic" label="Outlined" variant="outlined" />
<TextField inputRef={descRef} sx={{ width: '30%' }} id="outlined-basic" label="Outlined" variant="outlined" />
<Button sx={{ width: '30%' }} type='submit' variant='outlined'>Create</Button>
</Stack>
<div className={styles.todoView}>
{get.map((todo, i) =>
<Box component='button' key={i} className={styles.todoBody}>
<Stack flexDirection='row' alignItems='center'>
<Typography variant='h6'>{i + 1}.</Typography>
<Typography variant='body1'>{todo.title}</Typography>
</Stack>
<Button color='error'>Delete</Button>
</Box>
)}
</div>
</div>
)
}
export default MainPage