Skip to content

kcg-edu-future-lab/madoi-tutorial

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 

Repository files navigation

madoi-tutorial

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>

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages