これは dev.to サイトへの 14 回目の書き込みです。この投稿では、リアルタイム メッセージング機能を使用する興味深い方法を紹介します。
注: これはリアルタイム メッセージングの典型的なソリューションではありません。
Ably は開発者向けにさまざまなソリューションを提供しており、最も人気のあるソリューションはパブリッシュ/サブスクライブ モデルに基づくリアルタイム メッセージングです。メッセージをチャネルに公開すると、そのチャネルに接続されているすべてのデバイスが即座にメッセージを受信します。
Ably は、チャンネルのメッセージにメッセージの永続性を提供します (無料アカウントでは 24 時間)。特に興味深いのは、最後のメッセージを 365 日間保持できる機能です。 この例では、この機能を利用します。
概念は単純です。フォームとレコードのリスト (ToDo リスト、買い物リスト、連絡先リストなど) が単一の永続メッセージとして保存されている Web アプリまたはモバイル アプリを想像してください。任意のデバイス (PC、タブレット、または携帯電話) でアプリを起動すると、Ably からのデータが同期されます。データに加えた変更はすべて新しい永続メッセージとして保存され、すべてのデバイスからアクセスできる「リアルタイム データベース」を効果的に作成します。
考慮すべき制限がいくつかあります。メッセージの最大長は 64 KB (メタデータ、ID、タイムスタンプなどを含む) です。 2 KB を超えるメッセージは送信のためにチャンクに分割されるため、Ably ではデータ サイズをこの制限より十分に小さく保つことをお勧めします。したがって、このソリューションは少量のデータに最適です。
このコンセプトをテストしたところ、完璧に機能しました。レコードを追加および削除すると、すべてのクライアント アプリケーション (Web/モバイル) の同期を保つメッセージの更新がトリガーされます。
flems.io 上に単一のページ (HTML CSS JS) として単純な概念実証を作成しました。自分で試してみるには、次のことを行う必要があります:
アプリには重要な部分、JS コードがあります:
const ably = new Ably.Realtime("put your API KEY here"); const channel = ably.channels.get('[?rewind=1]Realtime'); var persons = []; channel.subscribe("db", (message) => { persons = message.data; renderTable(); }); function addPerson() { const name = document.getElementById('name').value; const age = document.getElementById('age').value; const role = document.getElementById('role').value; if (name && age && role) { const newPerson = { name: name, age: age, role: role }; persons.push(newPerson); updatePersons(); document.getElementById('name').value = ''; document.getElementById('age').value = ''; document.getElementById('role').value = ''; } } function deletePerson(index) { persons.splice(index, 1); updatePersons(); } function updatePersons() { channel.publish("db", persons); } function renderTable() { const personTable = document.getElementById('personTable'); personTable.innerHTML = ''; persons.forEach((person, index) => { const row = `<tr> <td>${person.name}</td> <td>${person.age}</td> <td>${person.role}</td> <td><button onclick="deletePerson(${index})">( X )</button></td> </tr>`; personTable.innerHTML += row; }); }
flems.io 上の私のアプリ
これがあなたにインスピレーションを与えてくれることを願っています! :-)
以上が好奇心: Ably.io リアルタイム メッセージングを軽量データベースとして使用するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。