Задать вопрос
@AvKa3003

Почему выполняется функция при изменении состояния в компоненте react?

const [searchQuerry, setSearchQuerry] = useState('')
const sortedPosts = getSortedPosts()

Есть компонент с состоянием searchQuerry привязанным к одному кастомному input двухсторонним связыванием. Не каких взаимодействий больше нет, функционал ещё не реализован.

Я пока плохо понимаю как работает перерисовка.

Вопрос. Почему когда изменяется это состояние, выполняется функция getSortedPosts изменяющая sortedPosts который является пропсом и соответственно перерисовывается другой компонент. Повторю что это состояние не с чем пока ни связано кроме своего input.

На случай если нужен полный компонент:
import React, { useState } from 'react';
import PostForm from './components/PostForm';
import PostList from './components/PostList';
import MyInput from './components/UI/input/MyInput';
import MySelect from './components/UI/select/MySelect';
import './styles/App.css'

function App() {
  const [posts, setPosts] = useState([
    {id: 1, title: 'Javascript', body: '<3'},
    {id: 2, title: 'C#', body: 'Братка'},
    {id: 3, title: 'Python', body: 'dasdsa'}
  ]);

  const [selectedSort, setSelectedSort] = useState('')
  const [searchQuerry, setSearchQuerry] = useState('')
  const sortedPosts = getSortedPosts()
  // const sortedPosts = posts;
  // const asd = 'asdd'

  const createPost = (newPost) => {
    setPosts([...posts, newPost]);
  }

  const removePost = (post) => {
    setPosts(posts.filter(p => p.id !== post.id))
  }
  
  const sortPosts = (sort) => {
    setSelectedSort(sort);
  }

  function getSortedPosts() {
    console.log('getSortedPosts')
    if(selectedSort) {
      return [...posts].sort((a, b) => a[selectedSort].localeCompare(b[selectedSort]))
    }
    return posts
  }

  return (
    <div className="App">
      <PostForm create={createPost}/>
      <hr style={{margin: '15px 0'}} />
      <div>
        <MyInput placeholder="Поиск" value={searchQuerry} onChange={e => setSearchQuerry(e.target.value)}/>
        <MySelect 
          value={selectedSort}
          onChange={sortPosts}
          defaultValue="Сортировка" 
          options={[
            {value: 'title', name:'По названию'},
            {value: 'body', name:'По описанию'}
          ]}
        />
      </div>
      {posts.length
        ? 
          <PostList remove={removePost} posts={sortedPosts} title="Список постов"/>
        : 
          <h1 style={{textAlign: 'center'}}>Посты не найдены.</h1>
      }
    </div>
  );
}

export default App;
  • Вопрос задан
  • 88 просмотров
Подписаться 1 Простой 1 комментарий
Решения вопроса 1
Devilz_1
@Devilz_1
Frontend-Developer
Вы запускаете эту функцию, когда присваиваете её выполнение константе sortedPosts.
Сколько раз перерендерили компонент, столько раз и запустили эту функцию
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы