Отличия Next и React
2 года назад·4 мин. на чтение
В этой статье рассмотрим ключевые особенности NextJS и ReactJS.
Перед разработкой веб-приложения необходимо принять решение, какой фреймворк или библиотеку использовать. Не секрет, что React — самая популярная JavaScript библиотека в мире.
Хорошим показателем популярности является активность сообщества вокруг определенной темы. И мы видим, что люди охотнее всего задают вопросы и отвечают на них в темах React
Однако, если вы решили использовать React для своего веб-приложения, возможно, вы слышали о Next и о том, что в некоторых вещах он лучше, чем React. Рост популярности Next показывает, что разработчики доверяют ему, хотя это относительно новый конкурент по сравнению с другими фреймворками и самим React.
Что такое React?
Прежде чем мы перейдем к сравнению Next и React, нужно получить некоторые базовые знания о React и Next. Библиотека React была создана Facebook в 2011 году, в 2013 году был открыт ее исходный код. Описание React гласило, что это эффективная, гибкая и декларативная JavaScript библиотека для создания интерактивных веб-приложений. React действительно хорош в разработке веб-приложений, которые требуют постоянного изменения данных в пользовательском интерфейсе. Если вы когда-либо разрабатывали веб-сайт с использованием только примитивных технологий, вы знаете, что после нажатия практически любого элемента веб-сайт обновляется. В наше время сложно найти что-то подобное в сети. Основным строительными блоками React приложений являются компоненты. Они отображают данные, когда эти данные изменяются, React обновляет интерфейс и генерирует новые данные. Этот процесс называется рендерингом.Почему React не фреймворк?
В сети существует множество споров о том, является ли React фреймворком или библиотекой. Это библиотека. Разработчики обычно используют термины «библиотека» и «фреймворк» взаимозаменяемо, однако это не одно и то же. Основными критериями для фреймворков являются:- Фреймворки предоставляют готовые к использованию инструменты, стандарты и шаблоны для быстрой разработки приложений, а библиотеки — нет.
- Фреймворки контролируют вызов библиотек для нашего кода.
- Фреймворки предоставляют правила и рекомендации по написанию кода и структурированию файлов и папок.
- Фреймворки имеют согласованный API, компиляторы, наборы инструментов и библиотеки внутри.
- Когда вы используете фреймворк, управление инвертируется, т. е. фреймворк управляет потоком и вызывает ваш код, в отличие от библиотек, которые позволяют вам управлять потоком приложения.
Что такое Create React App (CRA)?
Чтобы конкурировать с фреймворками, у React есть специальный фреймворк под названием Create React App (CRA). Он включает в себя структурирование файлов и другие инструменты, чтобы React можно было использовать в качестве фреймворка. Это лучший способ создания нового одностраничного приложения в React. CRA создает окружение для создания веб-приложения на основе React и сразу же оптимизирует ваше приложение для продакшена.Что такое Next?
Next, созданный Vercel и выпущенный в 2016 году, представляет собой легковесную платформу с открытым исходным кодом. Он был создан на основе React, чтобы сделать его удобнее и добавить дополнительные функции. Он используется для создания оптимизированных и быстрых веб-приложений благодаря server side рендерингу. Next популярен среди фреймворков, отчасти из-за его особенностей:- Typescript. Этот язык очень популярен, и я бы порекомендовал выучить его, если вы еще этого не сделали.
- Redux. Next полностью поддерживает Redux, что очень нравится разработчикам React.
- Оптимальная скорость. Next умеет рендерить страницы на стороне сервера разными способами. Первый — это привычный рендеринг на стороне сервера (SSR), который позволяет нам извлекать данные и отображать их во время запроса. Второй - статическая генерация, которая использует данные, доступные до запроса, что помогает кэшировать данные и улучшать SEO. Таким образом, поисковые роботы могут взаимодействовать с полностью готовой HTML-страницей. Vercel утверждает, что Next — один из самых быстрых фреймворков.
- Конфигурируемость. Next легко настраивается. Автоматически генерируемые решения для стилей упрощают разработку и предоставляют стартовые шаблоны для запуска вашего проекта.
- Маршрутизация. Создавать маршруты страниц так же просто, как создавать папки.
Отличия Next и React
Теперь, когда мы знаем основы Next и React, мы можем сравнить их и выяснить, почему они в целом являются хорошим выбором.Достоинства React
- Его легче учить, чем Next. React имеет хорошую документацию для быстрого начала работы.
- Для React есть сотни пакетов и инструментов, созданных для облегчения написания кода.
- Сильное сообщество с ~200000 звезд на Github на момент написания статьи значительно упрощает поиск помощи.
- Переиспользуемые компоненты позволяют разработчикам повторно использовать большую часть кода и создавать легко читаемый код.
- Инструмент Create React App позволяет разработчикам быстро и без проблем запускать свои проекты.
Недостатки React
- React приложения загружаются дольше и имеют плохую SEO оптимизацию. Next был создан с учетом SEO оптимизации.
- Производительность не так хороша, как у Next. Приложению нужно больше времени для загрузки.
- Разработчикам нужны такие инструменты, как CRA, для быстрого создания проекта. В противном случае настройка может оказаться сложной и занять слишком много времени.
- React развивается довольно быстро, поэтому разработчикам нужно следить за каждым обновлением React, поскольку новые функции могут быть добавлены в любое время. Документация быстро устаревает и не обязательно обновляется одновременно с обновлениями.
Достоинства Next
- Разработчикам не требуется дополнительная настройка для создания приложения SSR, в то время как для React требуется CRA.
- Не нужно беспокоиться о дополнительных инструментах или сборщиках, так как все делается за вас при создании проекта.
- Создан с учетом SEO. SSR улучшает качество страниц для поисковых роботов, которые посещают ваш сайт и собирают данные для поисковых систем.
- Производительность является большим преимуществом Next, поскольку приложения, созданные с его помощью, работают быстро благодаря SSR и статической генерации.
- Next оптимизирует изображения, что улучшает производительность.
- Next имеет собственную структуру папок, что делает процесс разработки интуитивно понятным и простым.
Недостатки Next
- Маршрутизация не такая гибкая, так как у Next есть своя встроенная.
- Без основ React будет сложнее создавать новые проекты.
Итоги
И Next, и React с CRA — отличные инструменты для удобной разработки. Next предоставляет быструю и легкую структуру, использующую SSR и отрисовку статического сайта. React, с другой стороны, отлично подходит для создания одностраничных веб-приложений. React более универсален, чем Next, так как это библиотека, а не фреймворк. Для пользователей React, уже знакомых с CRA, переход на Next не будет большой проблемой, а выигрыш может быть огромным с точки зрения SEO оптимизации и производительности.Продвинутое использование функций обратного вызова в React
2 года назад·4 мин. на чтение
В этой статье мы рассмотрим некоторые продвинутые функций обратного вызова (колбэк функции) в React, которые помогут вам создавать более эффективные и отзывчивые приложения. В частности, мы рассмотрим мемоизацию, debounce и throttle, а также разберем реальные примеры реализации этих методов в вашем коде.
Продвинутое использование функций обратного вызова являются неотъемлемой частью создания производительных и масштабируемых приложений, и это особенно актуально в разработке React приложений. Senior React разработчику важно иметь глубокое понимание продвинутых практик и того, как эффективно применять их в приложениях React.
К концу этой статьи вы будете иметь четкое представление об этих передовых методах обратного вызова и сможете использовать их в своих собственных приложениях React для повышения производительности и пользовательского опыта.
Что такое функции обратного вызова (callback, колбэк)?
Функция обратного вызова — это функция, которая передается в качестве аргумента другой функции и выполняется позже. Обратные вызовы используются для обработки асинхронного кода, например ожидания извлечения данных с сервера или обработки событий пользовательского ввода. В React обратные вызовы широко используются для обработки взаимодействия с пользователем и обновления состояния приложения. Например, когда пользователь нажимает кнопку, запускается функция обратного вызова для обработки события клика и соответствующего обновления состояния приложения.Пример простой функции обратного вызова
Вот базовый пример использования обратного вызова в React:В этом примере мы создадим классimport React from 'react'; class MyComponent extends React.Component { handleClick() { console.log('Button clicked'); } render() { return ( <button onClick={this.handleClick}>Click me</button> ); } }
MyComponent
, который расширяет класс React.Component
. Мы определяем метод handleClick
, который пишет сообщение в консоли при нажатии кнопки. Затем мы рендерим элемент button
с атрибутом onClick
, который задается методом handleClick
.
Этот пример представляет собой простую демонстрацию того, как обратные вызовы могут использоваться в React для обработки взаимодействий с пользователем.
Продвинутые функции обратного вызова
Теперь, когда мы рассмотрели основы обратных вызовов в React, давайте рассмотрим некоторые продвинутые функции обратного вызова, которые могут помочь senior инженерам создавать более эффективные и масштабируемые приложения.Мемоизация (memoization)
Мемоизация — это метод, используемый для оптимизации производительности функции путем кэширования ее результатов на основе входных параметров. Это может помочь уменьшить количество вызовов функции и повысить производительность приложения. В React запоминание можно использовать для оптимизации производительности компонентов, которые часто повторно рендерятся. Кэшируя результаты функции, мы можем избежать дорогостоящих вычислений, которые повторяются каждый раз при повторном рендеринге компонента. Вот пример того, как использовать мемоизацию в React:В этом примере мы используем хукimport React, { useMemo } from 'react'; function MyComponent(props) { const result = useMemo(() => { // Дорогостоящее вычисление return props.data.map(item => item * 2); }, [props.data]); return ( <div>{result}</div> ); }
useMemo
для запоминания результата дорогостоящих вычислений. Хук принимает два аргумента: функцию, которая выполняет дорогостоящие вычисления, и массив зависимостей, которые запускают вычисления при их изменении.
Используя хук useMemo
, мы можем избежать дорогостоящих вычислений, когда массив props.data
не изменяется.
Debounce
Debounce — это метод, используемый для предотвращения вызова функции несколько раз за короткий период времени. Это может помочь повысить производительность приложения и уменьшить количество ненужных вызовов функции. В React debounce можно использовать для обработки событий пользовательского ввода, таких как ввод в поле поиска. Применяя debounce для функции, которая обрабатывает событие ввода, мы можем избежать ненужных вызовов функции и повысить производительность приложения. Вот пример того, как использовать отмену в React:В этом примере мы используем библиотекуimport React, { useState, useEffect } from 'react'; import debounce from 'lodash.debounce'; function MyComponent() { const [searchQuery, setSearchQuery] = useState(''); useEffect(() => { const debouncedSearch = debounce(handleSearch, 500); document.addEventListener('keyup', debouncedSearch); return () => { document.removeEventListener('keyup', debouncedSearch); }; }, []); function handleSearch() { // Имитация вызова API console.log('Searching for:', searchQuery); } function handleChange(event) { setSearchQuery(event.target.value); } return ( <div> <input type="text" onChange={handleChange} /> </div> ); }
lodash.debounce
для отмены debounce’а функции handleSearch
. Мы добавляем прослушиватель событий к объекту документа для события keyup
, которое запускает функцию с debounce’ом. Мы также удаляем прослушиватель событий при размонтировании компонента, чтобы избежать утечек памяти.
Применив debounce к функции handleSearch
, мы можем предотвратить ее многократный вызов за короткий промежуток времени, что может помочь повысить производительность приложения.
Throttle
Throttle — это метод, используемый для ограничения количества вызовов функции за заданный период времени. Это может помочь повысить производительность приложения и уменьшить количество ненужных вызовов функции. В React throttle можно использовать для обработки событий пользовательского ввода, таких как прокрутка или изменение размера окна. Регулируя функцию, обрабатывающую входное событие, мы можем избежать ненужных вызовов функции и повысить производительность приложения. Вот пример использования throttle в React:В этом примере мы используем библиотекуimport React, { useState, useEffect } from 'react'; import throttle from 'lodash.throttle'; function MyComponent() { const [scrollPosition, setScrollPosition] = useState(0); useEffect(() => { const throttledScroll = throttle(handleScroll, 500); window.addEventListener('scroll', throttledScroll); return () => { window.removeEventListener('scroll', throttledScroll); }; }, []); function handleScroll() { const position = window.pageYOffset; setScrollPosition(position); } return ( <div> <p>Scroll position: {scrollPosition}</p> <div style={{ height: '2000px' }}> Content here </div> </div> ); };
lodash.throttle
для throttle'а функции handleScroll
. Мы добавляем прослушиватель событий к объекту окна для события scroll
, которое запускает функцию регулирования. Мы также удаляем прослушиватель событий при размонтировании компонента, чтобы избежать утечек памяти.
Применив throttle на функцию handleScroll
, мы можем ограничить количество вызовов за заданный период времени, что может помочь повысить производительность приложения.