ホームページ ウェブフロントエンド フロントエンドQ&A nodejsはシングルチャット機能を実装します

nodejsはシングルチャット機能を実装します

May 28, 2023 am 11:01 AM

Node.js はシングル チャット機能を実装します

Node.js は、Chrome の V8 エンジンをベースとした JavaScript 実行環境であり、サーバー側で JavaScript を実行できます。 Node.js を使用すると、高性能でスケーラブルな Web アプリケーションを簡単に構築できます。

この記事では、Node.js を使用して、単純な単一チャット機能、つまり 2 人のユーザー間のリアルタイム チャットを実装します。

必要なツールとテクノロジー:

    Node.js
  • Express Framework
  • Socket.IO
    プロジェクトの作成
まず、新しい Node.js プロジェクトを作成する必要があります。 npm init コマンドを使用してプロジェクトを初期化することも、他の方法を使用してプロジェクト フォルダーを作成することもできます。

    依存関係のインストール
次に、Express ライブラリと Socket.IO ライブラリをインストールする必要があります。プロジェクト フォルダーでコマンド ラインを開き、次のコマンドを入力します。

npm install express socket.io --save
ログイン後にコピー

これにより、Express ライブラリと Socket.IO ライブラリがインストールされ、package.json ファイルに追加されます。

    サーバーの作成
プロジェクト フォルダーに、server.js というファイルを作成します。これがメイン サーバー ファイルです。次のコードを追加します:

const express = require('express');
const app = express();

const server = app.listen(3000, () => {
  console.log('Server is listening on port 3000');
});
ログイン後にコピー

これにより、Express アプリケーションが作成され、ポート 3000 にバインドされます。これで、ブラウザを開いて http://localhost:3000 にアクセスして、サーバーが適切に実行されていることをテストできます。すべてが正常であれば、アプリケーションにルートを追加していないため、「Cannot GET /」というメッセージが表示されます。

    チャット ルームの作成
次に、2 人の異なるユーザー間のリアルタイム チャット機能を実装するためにチャット ルームを作成する必要があります。このために、Socket.IO ライブラリを使用してリアルタイムのイベントと通信を処理できます。

まず、次のコードをserver.js ファイルに追加する必要があります。

const io = require('socket.io')(server);

io.on('connection', (socket) => {
  console.log('A user connected');

  socket.on('disconnect', () => {
    console.log('A user disconnected');
  });
});
ログイン後にコピー

これにより、Socket.IO インスタンスが作成され、既存の HTTP サーバーにバインドされます。新しい接続がある場合、コールバック関数は「ユーザーが接続しました」というメッセージを出力します。接続が切断されると、コールバック関数は「ユーザーが切断されました」というメッセージを出力します。

これで、チャット ルームにメッセージを送受信する機能を追加できます。これには、Socket.IO の Emit() メソッドと on() メソッドを使用できます。

次のコードをserver.js ファイルに追加します。

io.on('connection', (socket) => {
  console.log('A user connected');

  socket.on('disconnect', () => {
    console.log('A user disconnected');
  });

  socket.on('chat message', (msg) => {
    console.log('message: ' + msg);
    io.emit('chat message', msg);
  });
});
ログイン後にコピー

これにより、ユーザーはメッセージを送信し、接続されているすべてのクライアントにメッセージをブロードキャストできるようになります。

    クライアントの作成
次に、単純な HTML と JavaScript ページを使用して Socket.IO サーバーに接続し、メッセージの送受信機能を実装する必要があります。プロジェクト フォルダーに、index.html という名前の新しいファイルを作成し、次のコードを追加します。

<!DOCTYPE html>
<html>
<head>
  <title>Node.js Chat</title>
</head>
<body>
  <ul id="messages"></ul>
  <form id="message-form">
    <input type="text" id="input-message" autocomplete="off" />
    <button>Send</button>
  </form>
  <script src="/socket.io/socket.io.js"></script>
  <script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
  <script>
    $(function () {
      const socket = io();
      $('#message-form').submit(function(e) {
        e.preventDefault(); // prevents page reloading
        const message = $('#input-message').val();
        socket.emit('chat message', message);
        $('#input-message').val('');
        return false;
      });
      socket.on('chat message', function(msg) {
        $('#messages').append($('<li>').text(msg));
      });
    });
  </script>
</body>
</html>
ログイン後にコピー

この HTML ファイルでは、DOM 操作を簡略化するために jQuery ライブラリを使用しています。これには、入力ボックスと「送信」ボタンに加えて、すべてのメッセージを表示する
    要素が含まれています。

    JavaScript 部分では、Socket.IO のクライアント側ライブラリを使用して、サーバーに接続する Socket.IO インスタンスを作成し、ユーザーがフォームを送信した後にサーバーにメッセージを送信しました。クライアントはサーバーから新しいメッセージを受信すると、新しいリスト項目をページに追加します。

      アプリケーションの開始
    コマンド ラインに次のコマンドを入力してアプリケーションを起動できます:

    node server.js
    ログイン後にコピー

    次に、Web を開きます。ブラウザで http://localhost:3000 にアクセスします。シンプルなチャット インターフェイスが表示されるはずです。別のブラウザ ウィンドウまたは同じコンピュータ上の別のブラウザ タブを開いて、チャットを開始します。

    概要

    この記事では、Node.js と Socket.IO ライブラリを使用して、リアルタイムのシングル チャット アプリケーションを構築しました。このアプリケーションを使用すると、ユーザーはメッセージを送受信でき、Socket.IO ライブラリを使用してすべてのリアルタイム通信を処理できます。このアプリケーションは比較的単純ですが、Node.js と Socket.IO を使用してリアルタイム Web アプリケーションを構築する方法の基本原則を示しています。

    以上がnodejsはシングルチャット機能を実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

UseEffectとは何ですか?副作用を実行するためにどのように使用しますか? UseEffectとは何ですか?副作用を実行するためにどのように使用しますか? Mar 19, 2025 pm 03:58 PM

この記事では、functionコンポーネントでのデータフェッチやDOM操作などの副作用を管理するためのフックであるReactの使用Effectについて説明します。メモリリークなどの問題を防ぐための使用、一般的な副作用、およびクリーンアップについて説明します。

connect()を使用して、ReactコンポーネントをReduxストアにどのように接続しますか? connect()を使用して、ReactコンポーネントをReduxストアにどのように接続しますか? Mar 21, 2025 pm 06:23 PM

記事では、Connect()、MapStateToprops、MapDispatchToprops、およびパフォーマンスへの影響を説明するReduxストアに反応コンポーネントをReduxストアに接続します。

usecontextとは何ですか?コンポーネント間で状態を共有するためにどのように使用しますか? usecontextとは何ですか?コンポーネント間で状態を共有するためにどのように使用しますか? Mar 19, 2025 pm 03:59 PM

この記事では、ReactのUseContextを説明しています。これにより、小道具掘削を避けることで国家管理を簡素化します。再レンダーの削減により、集中状態やパフォーマンスの改善などの利点について説明します。

イベントハンドラーのデフォルトの動作をどのように防止しますか? イベントハンドラーのデフォルトの動作をどのように防止しますか? Mar 19, 2025 pm 04:10 PM

記事では、PreventDefault()メソッドを使用して、イベントハンドラーのデフォルト動作の防止、ユーザーエクスペリエンスの強化などの利点、およびアクセシビリティの懸念などの潜在的な問題について説明します。

制御されたコンポーネントと制御されていないコンポーネントの利点と短所は何ですか? 制御されたコンポーネントと制御されていないコンポーネントの利点と短所は何ですか? Mar 19, 2025 pm 04:16 PM

この記事では、予測可能性、パフォーマンス、ユースケースなどの側面に焦点を当てた、Reactの制御されていないコンポーネントと制御されていないコンポーネントの利点と欠点について説明します。それらを選択する際に考慮することを要因についてアドバイスします。

HTMLにおけるReactの役割:ユーザーエクスペリエンスの向上 HTMLにおけるReactの役割:ユーザーエクスペリエンスの向上 Apr 09, 2025 am 12:11 AM

ReactはJSXとHTMLを組み合わせてユーザーエクスペリエンスを向上させます。 1)JSXはHTMLを埋め込み、開発をより直感的にします。 2)仮想DOMメカニズムは、パフォーマンスを最適化し、DOM操作を削減します。 3)保守性を向上させるコンポーネントベースの管理UI。 4)国家管理とイベント処理は、インタラクティブ性を高めます。

Arrayおよびオブジェクトの変更に関するVUE 2の反応性システムの制限は何ですか? Arrayおよびオブジェクトの変更に関するVUE 2の反応性システムの制限は何ですか? Mar 25, 2025 pm 02:07 PM

VUE 2の反応性システムは、直接配列インデックス設定、長さの変更、およびオブジェクトプロパティの追加/削除と闘っています。開発者は、Vueの突然変異法とVue.set()を使用して、反応性を確保することができます。

&lt; route&gt;を使用してルートをどのように定義しますか 成分? &lt; route&gt;を使用してルートをどのように定義しますか 成分? Mar 21, 2025 am 11:47 AM

この記事では、&lt; route&gt;を使用して、Reactルーターのルートの定義について説明します。パス、コンポーネント、レンダリング、子供、正確、ネストされたルーティングなどの小道具をカバーするコンポーネント。

See all articles