Если вы создали веб-приложение с использованием Next.js, но теперь вам нужно преобразовать его в чистое приложение React.js, вы не одиноки. Будь то простота, особые требования проекта или предпочтение рендеринга на стороне клиента, преобразование из Next.js в React может быть простым при правильном руководстве. В этой статье я расскажу вам, как преобразовать приложение Next.js в React.js, обеспечив плавный переход при сохранении основных функций вашего приложения.
Примечание: Если вместо этого вы хотите преобразовать приложение React.js в Next.js, прочтите другую мою статью о том, как преобразовать React.js в Next.js.
Next.js — это фантастический фреймворк, который предлагает рендеринг на стороне сервера (SSR), генерацию статического сайта (SSG) и множество других функций «из коробки». Однако эти функции могут быть излишними для небольших проектов или ненужными, если вы предпочитаете рендеринг на стороне клиента (CSR) с помощью React.js. Переход на React.js может упростить процесс сборки, уменьшить зависимость от сервера и дать вам больше контроля над архитектурой вашего приложения.
Прежде чем углубиться в процесс преобразования, важно понять ключевые различия между Next.js и React.js:
Давайте начнем с пошагового руководства по преобразованию приложения Next.js в React.js.
Сначала создайте новый проект React.js, используя такой инструмент, как Create React App (CRA) или Vite.
Использование приложения Create React:
npx create-react-app my-react-app cd my-react-app
Использование Vite:
npm init vite@latest my-react-app --template react cd my-react-app npm install
Скопируйте зависимости и devDependency из package.json вашего проекта Next.js в package.json нового проекта React.js. Запустите npm install или Yarn install, чтобы установить их.
Скопируйте содержимое каталогов компонентов и страниц Next.js в каталог src вашего проекта React.js. Поскольку Next.js использует для маршрутизации каталог страниц, вам необходимо настроить эту структуру.
Next.js автоматически обрабатывает маршрутизацию на основе каталога страниц. В React.js вам нужно будет настроить маршрутизацию вручную.
Установить React Router:
npm install react-router-dom
Настройте маршруты в src/App.js:
import { BrowserRouter as Router, Routes, Route } from 'react-router-dom' import Home from './Home' import About from './About' // Import other components as needed function App() { return () } export default App } /> } /> {/* Add other routes */}
В Next.js извлечение данных осуществляется с помощью getServerSideProps, getStaticProps или getInitialProps. В React.js вам нужно будет обрабатывать выборку данных внутри ваших компонентов, обычно используя useEffect и useState.
Пример:
import { useState, useEffect } from 'react' function Home() { const [data, setData] = useState([]) useEffect(() => { fetch('/api/data') // Update the API endpoint as needed .then((response) => response.json()) .then((data) => setData(data)) }, []) return{/* Render your data */}} export default Home
Если ваше приложение Next.js использует маршруты API в каталоге страниц/api, вам необходимо перенести их в отдельную серверную службу или настроить внешний интерфейс для получения данных из внешних API.
Параметры:
Next.js использует переменные среды с префиксом NEXT_PUBLIC_ для переменных на стороне клиента. В React.js создайте файл .env в корне вашего проекта и добавьте к переменным префикс REACT_APP_.
Пример:
REACT_APP_API_URL=https://api.example.com
Доступ к ним в вашем коде с помощью процесса.env.REACT_APP_API_URL.
Удалите все специфические конфигурации Next.js, например next.config.js. Кроме того, удалите все импортированные файлы или пакеты, специфичные для Next.js, которые больше не нужны.
Запустите приложение React.js, чтобы убедиться, что все работает должным образом.
npm start
Проверьте каждый маршрут и функциональность, чтобы убедиться, что преобразование прошло успешно.
Преобразование приложения Next.js в React.js включает в себя настройку нового проекта React и перенос ваших компонентов, настройку маршрутизации и другую обработку выборки данных. Хотя Next.js предлагает множество мощных функций, чистое приложение React.js обеспечивает простоту и гибкость, особенно для проектов, не требующих рендеринга на стороне сервера.
Следуя этому руководству по преобразованию Next.js в React.js, вы получите плавный переход.
Спасибо, что читаете! Если вы хотите пойти наоборот, прочтите мою статью о том, как преобразовать приложение React.js в Next.js. Чтобы узнать больше о новых проектах и статьях, подписывайтесь на меня в Твиттере: @jake_prins.
Отказ от ответственности: Все предоставленные ресурсы частично взяты из Интернета. В случае нарушения ваших авторских прав или других прав и интересов, пожалуйста, объясните подробные причины и предоставьте доказательства авторских прав или прав и интересов, а затем отправьте их по электронной почте: [email protected]. Мы сделаем это за вас как можно скорее.
Copyright© 2022 湘ICP备2022001581号-3