如何利用React和Express搭建全端JavaScript應用
如何利用React和Express來建立全端JavaScript應用程式
#引言:
React和Express是目前非常流行的JavaScript框架,它們分別用於建構前端和後端應用。本文將介紹如何結合使用React和Express來建構一個全端JavaScript應用程式。我們將逐步講解如何搭建一個簡單的TodoList應用,同時提供具體的程式碼範例。
一、準備工作
在開始之前,我們需要準備一些必要的工具和環境:
-
Node.js和npm:確保已經安裝了Node .js和npm(Node.js的套件管理器),可以透過命令列檢查它們是否已經安裝成功,如下所示:
node -v npm -v
登入後複製 - #建立專案資料夾:在你的工作目錄下建立一個新的資料夾,用來存放我們的全端應用程式碼。
二、後端建置
初始化專案:在專案資料夾下開啟命令列,執行下列命令來初始化新的Node.js項目:
npm init -y
登入後複製這將會建立一個預設的
package.json
文件,用來記錄專案的相關資訊和依賴套件。安裝Express和其他依賴:在命令列中執行以下命令來安裝Express和其他需要的依賴:
npm install express body-parser cors --save
登入後複製這裡我們安裝了Express、body-parser和cors,用來處理HTTP請求和跨域請求。
- 建立Express伺服器:在專案資料夾的根目錄下建立一個新的JavaScript文件,命名為
server.js
。打開server.js
,並加入以下內容:
const express = require('express'); const bodyParser = require('body-parser'); const cors = require('cors'); const app = express(); app.use(bodyParser.urlencoded({ extended: false })); app.use(bodyParser.json()); app.use(cors()); const PORT = process.env.PORT || 5000; app.listen(PORT, () => { console.log(`Server is running on port ${PORT}`); });
這段程式碼首先引入了需要的依賴套件,然後建立了一個Express實例並設定了一些中間件。最後,我們監聽指定的連接埠(預設是5000)。
- 新增路由與API:繼續編輯
server.js
,在現有的程式碼下方加入以下內容:
let todos = []; app.get('/api/todos', (req, res) => { res.json(todos); }); app.post('/api/todos', (req, res) => { const { todo } = req.body; todos.push(todo); res.json(todos); });
這段程式碼定義了兩個路由:一個用於取得所有的todo項,一個用於新增新的todo項。我們使用一個簡單的陣列todos
來儲存所有的todo項。
啟動伺服器:在命令列中執行以下命令來啟動Express伺服器:
node server.js
登入後複製如果一切正常,你將會在命令列中看到
Server is running on port XXXX
的提示,表示伺服器已成功啟動。
三、前端搭建
建立React應用程式:回到專案資料夾,在命令列中執行以下指令來建立一個新的React應用程式:
npx create-react-app client
登入後複製這將會在專案資料夾下建立一個名為
client
的新資料夾,用來存放我們的React前端應用程式碼。- 編輯React元件:開啟剛剛建立的
client/src/App.js
文件,將其中的程式碼替換為以下內容:
import React, { useState, useEffect } from "react"; function App() { const [todos, setTodos] = useState([]); const [newTodo, setNewTodo] = useState(""); useEffect(() => { fetch("/api/todos") .then(res => res.json()) .then(data => setTodos(data)); }, []); const handleInputChange = e => { setNewTodo(e.target.value); }; const handleSubmit = e => { e.preventDefault(); const todo = { todo: newTodo }; fetch("/api/todos", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify(todo) }) .then(res => res.json()) .then(data => setTodos(data)) .catch(err => console.log(err)); setNewTodo(""); }; return ( <div> <h1 id="Todo-List">Todo List</h1> <form onSubmit={handleSubmit}> <input value={newTodo} onChange={handleInputChange} /> <button type="submit">Add Todo</button> </form> <ul> {todos.map((todo, index) => ( <li key={index}>{todo}</li> ))} </ul> </div> ); } export default App;
這段程式碼定義了一個React函數元件App
,它用來展示todo列表。元件中使用了useState
和useEffect
兩個React的Hook來處理元件的狀態和副作用。我們透過fetch
函數來發送HTTP請求和取得資料。
啟動React應用程式:在專案資料夾下開啟命令列,進入
client
資料夾,並執行下列命令啟動React開發伺服器:npm start
登入後複製如果一切正常,你將會在瀏覽器中看到一個簡單的TodoList應用,你可以新增新的todo項目。
結束語:
透過本文的步驟,我們成功地結合使用React和Express建構了一個簡單的全端JavaScript應用程式。你可以根據自己的需求進一步擴展應用的功能,例如新增編輯和刪除功能,或是使用資料庫來儲存資料。全端開發能讓我們同時充分發揮前後端技術的優勢,提升開發效率,希望這篇文章對你有幫助。
以上是如何利用React和Express搭建全端JavaScript應用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

如何利用React和RabbitMQ建立可靠的訊息傳遞應用程式引言:現代化的應用程式需要支援可靠的訊息傳遞,以實現即時更新和資料同步等功能。 React是一種流行的JavaScript庫,用於建立使用者介面,而RabbitMQ是一種可靠的訊息傳遞中間件。本文將介紹如何結合React和RabbitMQ建立可靠的訊息傳遞應用,並提供具體的程式碼範例。 RabbitMQ概述:

ReactRouter使用指南:如何實現前端路由控制隨著單頁應用的流行,前端路由成為了一個不可忽視的重要部分。 ReactRouter作為React生態系統中最受歡迎的路由庫,提供了豐富的功能和易用的API,使得前端路由的實作變得非常簡單和靈活。本文將介紹ReactRouter的使用方法,並提供一些具體的程式碼範例。安裝ReactRouter首先,我們需要

PHP、Vue和React:如何選擇最適合的前端框架?隨著互聯網技術的不斷發展,前端框架在Web開發中起著至關重要的作用。 PHP、Vue和React作為三種代表性的前端框架,每一種都具有其獨特的特徵和優勢。在選擇使用哪種前端框架時,開發人員需要根據專案需求、團隊技能和個人偏好做出明智的決策。本文將透過比較PHP、Vue和React這三種前端框架的特徵和使

Java框架與React框架的整合:步驟:設定後端Java框架。建立專案結構。配置建置工具。建立React應用程式。編寫RESTAPI端點。配置通訊機制。實戰案例(SpringBoot+React):Java程式碼:定義RESTfulAPI控制器。 React程式碼:取得並顯示API回傳的資料。

深入比較Express和Laravel:如何選擇最佳框架?在選擇一個適合自己專案的後端框架時,Express和Laravel無疑是兩個備受開發者歡迎的選擇。 Express是基於Node.js的輕量級框架,而Laravel則是基於PHP的流行框架。本文將深入比較這兩個框架的優缺點,並提供具體的程式碼範例,以幫助開發者選擇最適合自己需求的框架。效能和擴展性Expr

Express和Laravel是兩個非常受歡迎的Web框架,分別代表了JavaScript和PHP兩大開發語言的優秀框架。本文將針對這兩個架構進行比較分析,幫助開發者選擇更適合自己專案需求的框架。一、框架簡介Express是一個基於Node.js平台的Web應用程式框架,它提供了一系列強大的功能和工具,使開發者可以快速建立高效能的網路應用程式。 Express

Vue.js適合中小型項目和快速迭代,React適用於大型複雜應用。 1)Vue.js易於上手,適用於團隊經驗不足或項目規模較小的情況。 2)React的生態系統更豐富,適合有高性能需求和復雜功能需求的項目。

react有事件處理函數、useEffect和useCallback、高階元件等等閉包。詳細介紹:1、事件處理函數閉包:在React中,當我們在元件中定義事件處理函數時,函數會形成一個閉包,可以存取元件作用域內的狀態和屬性。這樣可以在事件處理函數中使用元件的狀態和屬性,實現互動邏輯;2、useEffect和useCallback中的閉包等等。
