WebSocket通信ライブラリ Madoi のチュートリアルです。
Madoi を使うと、同じルームに参加しているアプリケーション全てに、メッセージを送信できます。
以下は、チャットアプリケーションの作成例です。
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="utf8">
<style>
#logDiv {
overflow: scroll;
resize: vertical;
height: 400px;
border: solid 1px;
padding: 4;
border-radius: 4px;
}
</style>
</head>
<body>
<form id="chatForm">
<input name="name" size="8" type="text" value="匿名">
<input name="message" size="30" type="text" placeholder="送信するメッセージ。enterで送信。">
<button type="submit">送信</button>
</form>
<div id="logDiv">
</div>
<script src="https://fungo.kcg.edu/madoi-20231023/js/madoi.js"></script>
<script>
window.addEventListener("load", ()=>{
// Madoiを作成しサーバに接続する。引数はルームのID。アプリケーション毎に異なるIDを使用する。
const m = new madoi.Madoi("chat-ldfngslkkeg");
const chatForm = document.getElementById("chatForm");
const logDiv = document.getElementById("logDiv");
chatForm.addEventListener("submit", e=>{
// フォームのsubmit時の処理
e.preventDefault();
const name = chatForm.name;
const message = chatForm.message;
// メッセージを送る。第一引数はメッセージタイプ、第二引数はメッセージの内容。
m.send("chat", `${name.value}: ${message.value}`);
message.value = "";
});
// "chat"タイプのメッセージを受信したら、logDivに内容を追加する。
m.setHandler("chat", message=>{
logDiv.innerHTML += message + "<br>";
logDiv.scrollTop = logDiv.scrollHeight;
});
});
</script>
</body>
</html>