検索
ホームページウェブフロントエンドjsチュートリアルReact と Express を使用してフルスタック JavaScript アプリケーションを構築する方法
React と Express を使用してフルスタック JavaScript アプリケーションを構築する方法Sep 26, 2023 pm 01:09 PM
reactexpressフルスタックアプリケーション

React と Express を使用してフルスタック JavaScript アプリケーションを構築する方法

React と Express を使用してフルスタック JavaScript アプリケーションを構築する方法

はじめに:
React と Express は現在非常に人気のある JavaScript フレームワークであり、フロントエンドとバックエンド アプリケーションをそれぞれ構築します。この記事では、React と Express を使用してフルスタック JavaScript アプリケーションを構築する方法を紹介します。シンプルな TodoList アプリケーションを構築する方法を段階的に説明し、具体的なコード例を示します。

1. 準備
始める前に、必要なツールと環境を準備する必要があります:

  1. Node.js と npm: Node がインストールされていることを確認します。 js と npm (Node.js のパッケージ マネージャー) については、次のようにコマンド ラインからそれらが正常にインストールされたかどうかを確認できます。

    node -v
    npm -v
  2. プロジェクト フォルダーを作成します: 作業ディレクトリ内に作成します。フルスタック アプリケーション コードを保存するための新しいフォルダー。

2. バックエンドの構築

  1. プロジェクトの初期化: プロジェクト フォルダーでコマンド ラインを開き、次のコマンドを実行して新しいノードを初期化します。 js プロジェクト :

    npm init -y

    これにより、プロジェクト関連の情報と依存パッケージを記録するためのデフォルトの package.json ファイルが作成されます。

  2. Express とその他の依存関係をインストールする: コマンド ラインで次のコマンドを実行して、Express とその他の必要な依存関係をインストールします:

    npm install express body-parser cors --save

    ここでは、Express と body-parser をインストールしました。 cors は、HTTP リクエストとクロスドメインリクエストを処理するために使用されます。

  3. 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) で待機します。

  1. ルーティングと 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);
});

このコード定義があります。ルートは 2 つあり、1 つはすべての Todo アイテムを取得するルート、もう 1 つは新しい Todo アイテムを追加するルートです。単純な配列 todos を使用して、すべての todo 項目を保存します。

  1. サーバーを起動します。 コマンド ラインで次のコマンドを実行して、Express サーバーを起動します。

    node server.js

    すべてが正常であれば、コマンド ライン Server is running on port XXXX プロンプトは、サーバーが正常に起動したことを示します。

3. フロントエンドの構築

  1. React アプリケーションを作成します: プロジェクト フォルダーに戻り、コマンド ラインで次のコマンドを実行して、新しい React アプリケーションを作成します:

    npx create-react-app client

    これにより、プロジェクト フォルダーの下に

    client という名前の新しいフォルダーが作成され、React フロントエンド アプリケーション コードが保存されます。

  2. React コンポーネントの編集: 作成したばかりの
  3. client/src/App.js ファイルを開き、その中のコードを次の内容に置き換えます:
  4. 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;
このコードは、ToDo リストを表示するために使用される React 関数コンポーネント

App を定義します。このコンポーネントは、2 つの React フック (useStateuseEffect) を使用して、コンポーネントの状態と副作用を処理します。 fetch 関数を使用して HTTP リクエストを送信し、データを取得します。

  1. React アプリケーションを起動します。プロジェクト フォルダーの下のコマンド ラインを開き、

    client フォルダーに入り、次のコマンドを実行して React 開発サーバーを起動します。 ##<pre class='brush:php;toolbar:false;'>npm start</pre> すべてがうまくいけば、ブラウザにシンプルな TodoList アプリケーションが表示され、新しい Todo アイテムを追加できます。

  2. 結論:
この記事の手順を通じて、React と Express を併用してシンプルなフルスタック JavaScript アプリケーションを構築することに成功しました。編集機能や削除機能の追加、データの保存にデータベースを使用するなど、ニーズに応じてアプリケーションの機能をさらに拡張できます。フルスタック開発を行うことで、フロントエンド技術とバックエンド技術の利点を同時に発揮し、開発効率を向上させることができます。

以上がReact と Express を使用してフルスタック JavaScript アプリケーションを構築する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
react中canvas的用法是什么react中canvas的用法是什么Apr 27, 2022 pm 03:12 PM

在react中,canvas用于绘制各种图表、动画等;可以利用“react-konva”插件使用canvas,该插件是一个canvas第三方库,用于使用React操作canvas绘制复杂的画布图形,并提供了元素的事件机制和拖放操作的支持。

React是双向数据流吗React是双向数据流吗Apr 21, 2022 am 11:18 AM

React不是双向数据流,而是单向数据流。单向数据流是指数据在某个节点被改动后,只会影响一个方向上的其他节点;React中的表现就是数据主要通过props从父节点传递到子节点,若父级的某个props改变了,React会重渲染所有子节点。

react中antd和dva是什么意思react中antd和dva是什么意思Apr 21, 2022 pm 03:25 PM

在react中,antd是基于Ant Design的React UI组件库,主要用于研发企业级中后台产品;dva是一个基于redux和“redux-saga”的数据流方案,内置了“react-router”和fetch,可理解为应用框架。

react中为什么使用nodereact中为什么使用nodeApr 21, 2022 am 10:34 AM

因为在react中需要利用到webpack,而webpack依赖nodejs;webpack是一个模块打包机,在执行打包压缩的时候是依赖nodejs的,没有nodejs就不能使用webpack,所以react需要使用nodejs。

react是组件化开发吗react是组件化开发吗Apr 22, 2022 am 10:44 AM

react是组件化开发;组件化是React的核心思想,可以开发出一个个独立可复用的小组件来构造应用,任何的应用都会被抽象成一颗组件树,组件化开发也就是将一个页面拆分成一个个小的功能模块,每个功能完成自己这部分独立功能。

react和reactdom有什么区别react和reactdom有什么区别Apr 27, 2022 am 10:26 AM

react和reactdom的区别是:ReactDom只做和浏览器或DOM相关的操作,例如“ReactDOM.findDOMNode()”操作;而react负责除浏览器和DOM以外的相关操作,ReactDom是React的一部分。

react中forceupdate的用法是什么react中forceupdate的用法是什么Apr 19, 2022 pm 12:03 PM

在react中,forceupdate()用于强制使组件跳过shouldComponentUpdate(),直接调用render(),可以触发组件的正常生命周期方法,语法为“component.forceUpdate(callback)”。

react有没有双向绑定react有没有双向绑定Apr 21, 2022 am 10:24 AM

react中没有双向绑定;react的设计思想就是单向数据流,没有双向绑定的概念;react是view层,单项数据流只能由父组件通过props将数据传递给子组件,满足了view层渲染的要求并且更易测试与控制,所以在react中没有双向绑定。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、