最近、Vue プロジェクトではデータをリアルタイムで更新する必要があります。折れ線グラフは 1 秒ごとに再描画され、データは 0.5 秒ごとに更新されます。簡単に言うとリアルタイム更新です。データ量が多いため、タイマーを使用してしばらく滞在するとページが固まってしまうことが予想されます。 。 。 バックエンドスタッフと話し合った結果、h5 に新しく追加された WebSocket を使用してリアルタイムのデータ表示を実現し、プロセスと発生した問題を記録することにしました。 注意: ページ更新のための長い接続は閉じられます。実際、現在のページに入るときに長い接続を確立する目的は、F5 を使わずにページを更新することです。すべてのデータはリアルタイムで自動的に更新されます。それでも F5 でページを何度も更新すると意味がありません。 。 。 追伸: 本当に必要な場合は、ページを更新して接続を維持する方法があるようです。Baidu で検索してください。 。 。 。 <テンプレート> <div> </div> </テンプレート> <スクリプト> エクスポートデフォルト{ データ() { 戻る { ウェブソック: null、 } }, 作成された(){ //ページに入ったときに長い接続を開く this.initWebSocket() }, 破棄: 関数() { //ページが破棄されたら長い接続を閉じます this.websocketclose(); }, メソッド: { initWebSocket(){ //wesocketを初期化する const wsuri = process.env.WS_API + "/websocket/threadsocket"; //ws アドレス this.websock = new WebSocket(wsuri); this.websocket.onopen = this.websocketonopen; this.websocket.onerror = this.websocketonerror; this.websocketonmessage は、次のメッセージを返します。 this.websocket.onclose は this.websocketclose です。 }, ウェブソケットオープン() { console.log("WebSocket接続が成功しました"); }, websocketonerror(e) { //エラー console.log("WebSocket接続エラー"); }, websocketonmessage(e){ //データ受信 const redata = JSON.parse(e.data); //注: 長時間の接続の場合、バックグラウンドで 1 秒あたり 1 つのデータを直接プッシュします。 //ただし、リストをクリックすると、識別子がバックエンドに送信され、バックエンドはこの識別子に基づいて対応するデータを返します。 //このとき、データは1つの出口からしか送出できないので、バックグラウンドにキーを追加します。例えば、キーが1のときは1秒ごとにデータをプッシュし、2のときはマークを送信してからデータをプッシュするなど、区別します。 console.log(redata.value); }, websocketsend(agentData){//データ送信 this.websock.send(agentData); }, websocketclose(e){ //閉じる console.log("接続が閉じられました (" + e.code + ")"); }, }, } </スクリプト> これで、Vue+WebSocket ページの長時間接続のリアルタイム更新の実装に関するこの記事は終了です。より関連性の高い Vue+WebSocket の長時間接続のリアルタイム更新コンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: MySQLデータベースで列を追加、削除、変更する方法
1. はじめにフロントエンドページのアニメーション効果を記述する場合、filter 属性は多かれ少な...
テキストカルーセルは私たちの日常生活で非常に一般的です。スーパーマーケットや実店舗の入り口には、テキ...
この記事では、テーブルページング機能を実現するためのVueの具体的なコードを例として紹介します。具体...
Web プロジェクトがどんどん大きくなると、CSS は天文学的な大きさと複雑さを増します。この問題を...
プロシージャ sp_name を削除します//これまで、MYSQL 構文の基礎知識について説明して...
1 はじめにデータベースを設計する場合、画像や音声ファイルをデータベースに挿入することは避けられませ...
1 MVCCとは何かMVCC の正式名称は、マルチバージョン同時実行制御です。データベースへの同時ア...
React の PC 版は Amap を使用するようにリファクタリングされました。情報を検索したと...
この記事では、例を使用して、MySQL 外部キーの 3 つの関係について説明します。ご参考までに、詳...
Docker コンテナのネットワーク障害に対する 6 つの解決策注: 以下の方法は、コンテナ内のパブ...
01. 概要絶対パスと相対パスはシェル環境でよく使用され、それぞれに独自の用途があります。相対パスの...
1. はじめにロケーション命令は、http モジュールのコア構成です。事前に定義された URL マッ...
この記事では、パーセンテージスコアリングプログレスバーを実現するためのjQueryの具体的なコードを...
目次1. 怠惰な2.トリム3.番号4.停止5. キャプチャ6.自分7.一度8.予防する9.ネイティブ...
ポーリングアルゴリズムの紹介多くの人が職場で nginx を使用しており、その設定に精通しています。...